Netbeans con connessione Oracle java.lang.ClassNotFoundException
-
19-09-2019 - |
Domanda
io uso NetBeans 6.5.
Quando si tenta di eseguire il seguente codice:
package com.afrikbrain.numeroteur16;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
*
* @author
*/
public class NumeroteurTest {
public NumeroteurTest() {
}
public void doIt() throws ClassNotFoundException{
try {
Class.forName("oracle.jdbc.OracleDriver");
Connection connection = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE","user","pwd");
String newNUMERO = new Numeroteur16("MATCLI", connection).numeroter();
System.out.println("NUMERO GENERE : "+newNUMERO.toString());
}
catch (SQLException ex) {
Logger.getLogger(NumeroteurTest.class.getName()).log(Level.SEVERE, null, ex);
ex.printStackTrace();
}
catch (NumException ex) {
System.out.println(ex.getMessage());
ex.printStackTrace();
}
}
public static void main(String[] args){
try {
new NumeroteurTest().doIt();
} catch (ClassNotFoundException ex) {
Logger.getLogger(NumeroteurTest.class.getName()).log(Level.SEVERE, null, ex);
System.out.println("Driver not found.");
}
}
}
ottengo questo errore:
java.lang.ClassNotFoundException: oracle.jdbc.OracleDriver
at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at com.afrikbrain.numeroteur16.NumeroteurTest.doIt(NumeroteurTest.java:27)
at com.afrikbrain.numeroteur16.NumeroteurTest.main(NumeroteurTest.java:45)
Driver not found.
Come faccio a risolvere questo problema?
Soluzione
Il problema: Java non riesce a trovare la classe di driver JDBC
.
Soluzione: aggiungere il driver JDBC Oracle al classpath
.
Si può arrivare a http://www.oracle.com /technology/software/tech/java/sqlj_jdbc/index.html
Inizia Java con java -classpath ojdbc14.jar ...
per includere il vaso scaricato nel classpath.
Altri suggerimenti
Aggiungi ojdbc6.jar
alle librerie del progetto. In primo luogo, creare una nuova libreria (NetBeans):
- NetBeans -> Strumenti -> Biblioteche -> Nuova libreria (Usare un nome descrittivo per esempio:. OracleJDBC6)
- Fare clic su OK , quindi Aggiungi JAR / cartella .
- Tipo
%ORACLE_HOME%\jdbc\lib\ojdbc6.jar
, quindi confermare. Sul mio computer,ORACLE_HOME=c:\app\admin\product\11.2.0\dbhome_1
.
Infine, aggiungere la libreria al progetto:. Fare clic destro su Biblioteche , selezionare Aggiungi libreria e selezionare la libreria precedentemente aggiunto
Assicurarsi che il driver Oracle è nel classpath. Il driver sottile è in ojdbc14.jar.