これは一般的な問題のようですが、実用的な解決策を見つけることができませんでした。私は何十ものスレッドを調べて、先生と一緒に働いてきました。JDBCを使用してMYSQLに接続しようとしています。また、Tomcatサーバーを使用しており、xubuntu12.04を実行しています。ClassNotFound例外が発生します。
/ tomact/libと/usr/ share /javaの両方に配置されたJDBCmysql-connector-java.jarドライバーを試し、各インスタンスに手動でパスを作成しました。また、デプロイアセンブリを介してパスを追加してみました。EXPORTCLASSPATHを使用してみました。何も機能していません。この例外のスローを停止することはできません。誰かが私が試すことができる他の解決策を持っていますか?
私のコード:
public static Connection getConnection() {
if(connection!=null){
return connection;
}else{
try{
Class.forName("com.mysql.jdbc.Driver").newInstance();
String dbURL = "jdbc:mysql://144.91.20.136:3306/jewelryInventoryGallison";
String username = "javaee";
String password = "mills2012";
connection = DriverManager.getConnection(dbURL, username, password);
return connection;
} catch (Exception ex) {
ex.printStackTrace();
return null;
}
}
}
テストクラス:
public static void main(String[] args) throws Exception{
Connection conn = DatabaseUtils.getConnection();
Statement st = conn.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM Inventory");
while(rs.next()) {
System.out.println(rs.getString("name"));
}
}
およびトレース:
java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:186)
at utils.DatabaseUtils.getConnection(DatabaseUtils.java:19)
at utils.DatabaseUtils.main(DatabaseUtils.java:34)
utils.DatabaseUtils.main(DatabaseUtils.java:35)でのスレッド「main」java.lang.NullPointerExceptionの例外
あなたの助けは大歓迎です!