ru_java


ru.java

все о языке программирования java


Previous Entry Share Next Entry
наступил на грабли classpath или что ?
n1919 wrote in ru_java
делаю тестовый пример, по типу HelloWorld.


import java.sql.*;
//import oracle.jdbc.driver.OracleDriver;
import oracle.jdbc.OracleDriver;

public class test
{

public static void log(String s)
{
System.out.println(s);
}

public static void main(String[] args)
{
log("begin test");


String server = "localhost";
String port = "1521";
String sid = "XE";
String url = "jdbc:oracle:thin:@" + server + ":" + port + ":" + sid;

try
{
Connection conn = DriverManager.getConnection(url, "hr","hr");
}
catch (SQLException e)
{
log(e.toString());
}

log("end test");
}

}


компилируется и запускается
но коннект не видит класс:

begin test
java.sql.SQLException: No suitable driver found for jdbc:oracle:thin:@localhost:1521:XE
end test

интересно, однако, что import-то вроде проходит, иначе бы не компилировалось.

стоит отметить, что для простоты всё в одной директории.
ojdbc6.jar там же.

может не очень хорошо, но я выбрал пока так.
никакой IDE, только командная строка.

компиляция так:

"C:\Program Files\Java\jdk1.7.0_79\bin\javac" -classpath ".;.\*" .\test.java

запуск:

"C:\Program Files\Java\jdk1.7.0_79\bin\java" test -classpath ".;.\*"

пробовал писать jar явно: -classpath ".;.\ojdbc6.jar"

чё может быть ?
может jar какой-то не той версии ?
но я вроде последний качал.

  • 1
Вообще, даже до JDBC 4 почти никто явно не использовал registerDriver() напрямую, т.к. это делает сам друйвер. Такой вызов можно было увидеть разве что в паре registerDriver()/deregisterDriver().

  • 1
?

Log in

No account? Create an account