Android - 关于使用 jdbc 连接到 MSSQL 的 classnotfound

Posted

技术标签:

【中文标题】Android - 关于使用 jdbc 连接到 MSSQL 的 classnotfound【英文标题】:Android - classnotfound on using jdbc connecting to MSSQL 【发布时间】:2012-11-22 11:20:27 【问题描述】:

我正在尝试制作一个从 MSSQL Server 2008 读取数据的 android 应用程序。我发现 an example 关于使用 JDBC,但它不适合我。

我已关注 Roger Garza 的 this post 的回答,但仍未找到该课程

我无法导入要发布的图像,但我在 Android 依赖项下有 jtds-1.3.0.jar。

我的代码是:

public void query2()

Log.i("Android"," mysql Connect Example.");
Connection conn = null;
try 
String driver = "net.sourceforge.jtds.jdbc.Driver";
Class.forName(driver).newInstance();

String connString = "jdbc:jtds:sqlserver://MYIPSERVER:1433/SERVERNAME;encrypt=false;user=sa;password=password;instance=SQLEXPRESS";
String username = "sa";
String password = "password";
conn = DriverManager.getConnection(connString,username,password);
Log.w("Connection","open");
Statement stmt = conn.createStatement();
ResultSet reset = stmt.executeQuery("select TOP 10 * from MyTable ORDER BY Transac DESC");

//Print the data to the console
while(reset.next())
Log.w("Data:",reset.getString(3));
//              Log.w("Data",reset.getString(2));

conn.close();

 catch (Exception e)

Log.w("Error connection","");
e.printStackTrace();


错误就在这一行之后 - Class.forName(driver).newInstance(); - 因为我在之后评论了代码并且我有相同的错误日志。 日志是:

11-21 16:05:55.480: I/Android(1679):  MySQL Connect Example.
11-21 16:05:55.499: W/System.err(1679): java.lang.ClassNotFoundException: net.sourceforge.jtds.jdbc.Driver
11-21 16:05:55.499: W/System.err(1679):     at java.lang.Class.classForName(Native Method)
11-21 16:05:55.509: W/System.err(1679):     at java.lang.Class.forName(Class.java:217)
11-21 16:05:55.509: W/System.err(1679):     at java.lang.Class.forName(Class.java:172)
11-21 16:05:55.509: W/System.err(1679):     at com.example.holz1.MainActivity.query2(MainActivity.java:46)
11-21 16:05:55.509: W/System.err(1679):     at com.example.holz1.MainActivity.onClick(MainActivity.java:35)
11-21 16:05:55.509: W/System.err(1679):     at java.lang.reflect.Method.invokeNative(Native Method)
11-21 16:05:55.509: W/System.err(1679):     at java.lang.reflect.Method.invoke(Method.java:511)
11-21 16:05:55.519: W/System.err(1679):     at android.view.View$1.onClick(View.java:3039)
11-21 16:05:55.519: W/System.err(1679):     at android.view.View.performClick(View.java:3511)
11-21 16:05:55.519: W/System.err(1679):     at android.view.View$PerformClick.run(View.java:14105)
11-21 16:05:55.529: W/System.err(1679):     at android.os.Handler.handleCallback(Handler.java:605)
11-21 16:05:55.529: W/System.err(1679):     at android.os.Handler.dispatchMessage(Handler.java:92)
11-21 16:05:55.543: W/System.err(1679):     at android.os.Looper.loop(Looper.java:137)
11-21 16:05:55.543: W/System.err(1679):     at android.app.ActivityThread.main(ActivityThread.java:4424)
11-21 16:05:55.543: W/System.err(1679):     at java.lang.reflect.Method.invokeNative(Native Method)
11-21 16:05:55.549: W/System.err(1679):     at java.lang.reflect.Method.invoke(Method.java:511)
11-21 16:05:55.549: W/System.err(1679):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
11-21 16:05:55.549: W/System.err(1679):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
11-21 16:05:55.549: W/System.err(1679):     at dalvik.system.NativeStart.main(Native Method)
11-21 16:05:55.599: W/System.err(1679): Caused by: java.lang.NoClassDefFoundError: net/sourceforge/jtds/jdbc/Driver
11-21 16:05:55.599: W/System.err(1679):     ... 19 more
11-21 16:05:55.610: W/System.err(1679): Caused by: java.lang.ClassNotFoundException: net.sourceforge.jtds.jdbc.Driver
11-21 16:05:55.619: W/System.err(1679):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61)
11-21 16:05:55.619: W/System.err(1679):     at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
11-21 16:05:55.629: W/System.err(1679):     at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
11-21 16:05:55.629: W/System.err(1679):     ... 19 more
11-21 16:06:51.519: W/WindowManager(90): Failure taking screenshot for (180x300) to layer 21010
11-21 16:06:51.552: W/NetworkManagementSocketTagger(90): setKernelCountSet(10013, 1) failed with errno -2
11-21 16:06:52.499: W/NetworkManagementSocketTagger(90): setKernelCountSet(10047, 0) failed with errno -2

【问题讨论】:

我会推荐您的服务器使用 REST API 来提供数据,而不是直接连接。请始终牢记,在移动设备上,您可能会定期失去连接。随着时间的推移,打开的数据库连接可能会成为一个严重的问题...... 【参考方案1】:

我认为是jar引起的,请下载sqljdbc-1.2.0.jar并将其放在根目录下的lib文件夹中

download sqljdbc-1.2.0.jar

【讨论】:

是的,我发现 v1.3.0 上发生了同样的事情。我使用了 1.2.7 并且每个都按预期工作。这真的是谁的错我不确定......

以上是关于Android - 关于使用 jdbc 连接到 MSSQL 的 classnotfound的主要内容,如果未能解决你的问题,请参考以下文章

使用 jdbc Java、Android 应用程序连接到 SQL Server 数据库

无法使用 JDBC 在 android 中连接到 sql server 2008

我无法使用带有 Android Studio 的 JDBC 连接到 SQL Server Express

android中的jdbc问题 - 无法连接到数据库

Android 连接到远程 mysql 数据库 JDBC Vs JSON

如何使用库 jTDS JDBC 驱动程序将 android 应用程序连接到 sql server 2012