我想从使用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)
而不是e.getMessage(),你可以尝试与e.printStackTrace()并提供给我们stacktrace? –
具有Driver类而非驱动程序类的MySQL jar。试试看Class.forName(“com.mysql.jdbc.Driver”);请给堆栈跟踪进一步调查。 –
另外什么是确切的例外 - 因为这给了更多的信息,只是有一个例外 – Mark