2013-01-07 73 views
1

我想从使用JDBC的表中获取所有列值。在Java中连接到数据库的异常:JDBC

这是我在我的主程序中编写的代码。

Class.forName("com.mysql.jdbc.driver"); 
String url = "jdbc:jtds:sqlserver://test.com/abc_1_20121225;instance=abcd"; 
Connection conn = DriverManager.getConnection(url,"uname","pwd"); 
Statement stmt = conn.createStatement(); 
ResultSet rs; 

    rs = stmt.executeQuery("SELECT table_name, column_name, data_type, data_length FROM USER_TAB_COLUMNS WHERE table_name = 'MyTable'"); 
    while (rs.next()) { 
     String colName = rs.getString("column_name"); 
        System.out.println(colName); 
     } 
    conn.close(); 
} catch (Exception e) { 
    System.err.println("Got an exception! "); 
System.err.println(e.getMessage()); 

我在我的课程路径中添加了jtds.jar。我收到此消息

Got an exception! 
com.mysql.jdbc.driver 

有人能告诉我问题的确切原因吗?

编辑:

添加stactrace;

java.lang.ClassNotFoundException: com.mysql.jdbc.driver 
at java.net.URLClassLoader$1.run(Unknown Source) 
at java.net.URLClassLoader$1.run(Unknown Source) 
at java.security.AccessController.doPrivileged(Native Method) 
at java.net.URLClassLoader.findClass(Unknown Source) 
at java.lang.ClassLoader.loadClass(Unknown Source) 
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) 
at java.lang.ClassLoader.loadClass(Unknown Source) 
at java.lang.Class.forName0(Native Method) 
at java.lang.Class.forName(Unknown Source) 
at schwab.TestDB.main(TestDB.java:15) 
+4

而不是e.getMessage(),你可以尝试与e.printStackTrace()并提供给我们stacktrace? –

+3

具有Driver类而非驱动程序类的MySQL jar。试试看Class.forName(“com.mysql.jdbc.Driver”);请给堆栈跟踪进一步调查。 –

+0

另外什么是确切的例外 - 因为这给了更多的信息,只是有一个例外 – Mark

回答

3

你的错装驱动程序。

替换此:

Class.forName("com.mysql.jdbc.driver"); 

随着

Class.forName("net.sourceforge.jtds.jdbc.Driver"); 
+0

非常感谢。 – Patan

0

我的猜测是你没有你的classpath上的MysQL驱动。但是,如果你提供完整的堆栈跟踪,你应该能够确认这一点。

但是,它看起来像你正在使用SQLServer数据库,所以我不知道你为什么引用MYSQL驱动程序?

3

Class.forName("com.mysql.jdbc.driver");

- >如果你正在使用MySQL驱动程序,它是驱动程序类不是司机。

String url = "jdbc:jtds:sqlserver://test.com/abc_1_20121225;instance=abcd";

--->您的网址将指向SQL Server数据库。

确定您正在使用哪个数据库。如果您使用MySQL,请使用MySQL Connector jar和驱动程序类com.mysql.jdbc.Driver

如果您正在使用MS SQL Server,使用驱动程序类:net.sourceforge.jtds.jdbc.DriverjTDS Driver OR com.microsoft.sqlserver.jdbc.SQLServerDriver为Microsoft SQL Server 2005 JDBC驱动程序

-1

下载sqljdbc4-2.0.jar,并与您的项目连接。它会解决你的问题。

+0

OP正在尝试加载MySQL驱动程序,而URL是一个jTds URL。将官方SQL Server驱动程序添加到项目中并不会解决任何问题... –