java - UCanAccess 初始化程序错误(在没有 IDE 的情况下编译/运行)

标签 java jdbc ucanaccess

我一直在尝试创建一个新项目来使用 UCanAccess 读取 MS Access 文件。我一直在关注 @Gord Thompson 的信息以及 UCanAccess 的 github 中的示例文件。排除我使用不同名称的事实,一切都是一样的。我不使用任何 GUI IDE。我只是从命令行编译,基本上,我编写了一个进行命令行编译的Java程序。

引用文献:

Manipulating an Access database from Java without ODBC

https://github.com/andrew-nguyen/ucanaccess/blob/master/example/net/ucanaccess/example/Example.java

我的代码示例如下:

String path = new java.io.File(PATH).getAbsolutePath();
db = "jdbc:ucanaccess://" + path;
Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
Connection conn = DriverManager.getConnection( db );
Statement s = conn.createStatement();

我的错误消息是:

Exception in thread "main" java.lang.ExceptionInInitializerError
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at GreatBeyond.<init>(GreatBeyond.java:36)
    at GreatBeyond.main(GreatBeyond.java:66)
Caused by: java.lang.RuntimeException: org.hsqldb.jdbc.JDBCDriver
    at net.ucanaccess.jdbc.UcanaccessDriver.<clinit>(UcanaccessDriver.java:54)
    ... 4 more

第 36 行是“Class.forName”,我尝试在没有它的情况下运行程序,但失败了。我已经下载了 UCanAccess 的 zip 文件并将其解压到 com 目录,Jackcess 被解压到 net 目录。谁能指出出了什么问题吗?

最佳答案

如果您不使用 IDE,则需要为 UCanAccess 的 JAR 文件及其所有依赖项(HSQLDB、Jackcess 等)指定 CLASSPATH 条目。一种方法是在运行代码时使用 java 命令的 -cp 选项。

例如,在“UcaNoIde.java”中编译以下代码后...

import java.sql.*;

public class UcaNoIde {

    public static void main(String[] args) {
        String dbFileSpec = "C:/Users/Public/UCanAccessTest.accdb";
        String connStr = "jdbc:ucanaccess://" + dbFileSpec;
        try (Connection conn = DriverManager.getConnection(connStr)) {
            System.out.println("Connection established.");
        } catch (Exception e) {
            e.printStackTrace(System.err);
        }
    }

}

...进入“UcaNoIde.class”文件我可以在 Windows 命令提示符下使用以下命令运行它:

java -cp .;C:/Users/Public/Downloads/UCanAccess/ucanaccess-3.0.3.jar;C:/Users/Public/Downloads/UCanAccess/lib/commons-lang-2.6.jar;C:/Users/Public/Downloads/UCanAccess/lib/commons-logging-1.1.1.jar;C:/Users/Public/Downloads/UCanAccess/lib/hsqldb.jar;C:/Users/Public/Downloads/UCanAccess/lib/jackcess-2.1.3.jar UcaNoIde

(对于 Linux,-cp 条目将用冒号 (:) 分隔,而不是分号 (;)并且文件路径会有点不同。)

另一种可能性是定义一个 CLASSPATH 环境变量,其条目与上面的 -cp 选项中的条目相同,这样您就不必每次都使用 -cp

关于java - UCanAccess 初始化程序错误(在没有 IDE 的情况下编译/运行),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34214108/

相关文章:

java - 如何在java中向数据库添加 boolean 值

java - UCanAccess:未找到合适的驱动程序

ms-access - UCAExc 3.0.7 无效事务状态 : read-only SQL-transaction Sometimes when saving to . accdb

java - Access DB 自动增量不允许我打开表

java - Android 游戏的连续计数计时器

java - Android 应用程序无法启动 Activity 组件信息

java - 随机调用向远程和本地数据库插入、检索和更新 mysql

java - 使用 jena 保存本体时出错

java - 如何计算耶拿猫头鹰类的人数?

java - 获取 Java mysql SQL 语法错误,但我的查询似乎正常