2

我正在尝试使用jtds jdbc driver连接到 sql server 。以下是代码

    try {
        Class.forName("net.sourceforge.jtds.jdbc.Driver");
        this.conn = DriverManager.getConnection(
                                   connectString, username, password);
        System.out.println("connected");            
    }
    catch (Exception e) {
        e.printStackTrace();
    }

包编译但是当我尝试在终端中使用以下命令运行它时

java -cp .:jtds-1.2.5.jar org.kodeplay.migration.TestConnection

它仍然会抛出 ClassNotFoundException。所以这似乎不是正确的方法。这个怎么做 ?

我已将 jtds-1.2.5.jar 文件复制到 ubuntu 桌面上 /etc/environment 文件中指定的类路径目录中

编辑:它打印的完整异常如下

java.lang.ClassNotFoundException: net.sourceforge.jtds.jdbc.Driver
at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:186)
at org.kodeplay.migration.SqlDb.connect(SqlDb.java:21)
at org.kodeplay.migration.TestConnection.main(TestConnection.java:13)
4

1 回答 1

2

我已将 jtds-1.2.5.jar 文件复制到 ubuntu 桌面上 /etc/environment 文件中指定的类路径目录中

为什么?在命令行上,您指定在当前目录中查找该文件。

仅当您未在命令行上手动指定类路径时才使用任何环境变量(设置在/etc/environment其他位置或其他任何位置)(执行 jar 文件时它们也会被忽略!)。

于 2011-01-21T08:45:26.333 回答