草庐IT

java - 在没有 ODBC 的情况下从 Java 操作 Access 数据库

coder 2023-04-27 原文

我想从我的 Java 项目中操作 Microsoft Access 数据库(.accdb 或 .mdb 文件)。我不想使用 Microsoft 的 JDBC-ODBC 桥和 Access ODBC 驱动程序,因为:

  • JDBC-ODBC 桥已从 Java SE 8 中删除,不受支持(引用:here),
  • 当文本包含代码点高于 U+00FF(引用:here)的 Unicode 字符时,JDBC-ODBC 桥无法与 Access ODBC 驱动程序一起正常工作,因此这样的设置将无法处理诸如希腊语、俄语、汉语、阿拉伯语等,
  • Microsoft 的 Access ODBC 驱动程序仅适用于 Windows,并且
  • Access 数据库引擎(和 ODBC 驱动程序)有单独的 32 位和 64 位版本,这可能会妨碍部署。

我看到其他答案提到了名为 UCanAccess 的 Access 数据库的 JDBC 驱动程序。 .如何设置我的 Java 项目以使用这种方法?

(也欢迎提出更好的从 Java 中使用 Access 数据库的方法的答案。)

最佳答案

UCanAccess是一个纯 Java JDBC 驱动程序,它允许我们在不使用 ODBC 的情况下读取和写入 Access 数据库。它使用另外两个包,JackcessHSQLDB , 来执行这些任务。以下是如何设置它的简要概述。

 

选项 1:使用 Maven

如果您的项目使用 Maven您可以通过以下坐标简单地包含 UCanAccess:

groupId: net.sf.ucanaccess
artifactId: ucanaccess

以下内容摘自pom.xml ,您可能需要更新 <version>获取最新版本:

  <dependencies>
    <dependency>
        <groupId>net.sf.ucanaccess</groupId>
        <artifactId>ucanaccess</artifactId>
        <version>4.0.4</version>
    </dependency>
  </dependencies>

 

选项 2:手动将 JAR 添加到您的项目中

如上所述,UCanAccess 需要 Jackcess 和 HSQLDB。 Jackcess 又拥有自己的dependencies .因此,要使用 UCanAccess,您需要包含以下组件:

UCanAccess (ucanaccess-x.x.x.jar)
HSQLDB (hsqldb.jar, 2.2.5 或更新版本)
Jackcess (jackcess-2.x.x.jar)
commons-lang (commons-lang-2.6.jar,或更新的 2.x 版本)
commons-logging (commons-logging-1.1.1.jar,或更新的 1.x 版本)

幸运的是,UCanAccess 在其分发文件中包含了所有必需的 JAR 文件。当你解压它时,你会看到类似的东西

ucanaccess-4.0.1.jar  
  /lib/
    commons-lang-2.6.jar  
    commons-logging-1.1.1.jar  
    hsqldb.jar  
    jackcess-2.1.6.jar

您需要做的就是将所有 五 (5) 个 JAR 添加到您的项目中。

NOTE: Do not add loader/ucanload.jar to your build path if you are adding the other five (5) JAR files. The UcanloadDriver class is only used in special circumstances and requires a different setup. See the related answer here for details.

Eclipse: 在 Package Explorer 中右键单击项目并选择 Build Path > Configure Build Path... .单击“添加外部 JAR...”按钮以添加五 (5) 个 JAR 中的每一个。完成后,您的 Java 构建路径应如下所示

NetBeans: 展开项目的 TreeView ,右键单击“Libraries”文件夹并选择“Add JAR/Folder...”,然后浏览到 JAR 文件。

添加所有五 (5) 个 JAR 文件后,“Libraries”文件夹应如下所示:

IntelliJ IDEA: 选择 File > Project Structure...从主菜单。在“库” Pane 中,单击“添加”(+) 按钮并添加五 (5) 个 JAR 文件。完成后,项目应如下所示:

 

就是这样!

现在使用这样的代码“你可以 Access ” .accdb 和 .mdb 文件中的数据

// assumes...
//     import java.sql.*;
Connection conn=DriverManager.getConnection(
        "jdbc:ucanaccess://C:/__tmp/test/zzz.accdb");
Statement s = conn.createStatement();
ResultSet rs = s.executeQuery("SELECT [LastName] FROM [Clients]");
while (rs.next()) {
    System.out.println(rs.getString(1));
}

 

披露

在撰写此问答时,我没有参与或隶属于 UCanAccess 项目;我刚用过。从那以后,我成为了该项目的贡献者。

关于java - 在没有 ODBC 的情况下从 Java 操作 Access 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21955256/

有关java - 在没有 ODBC 的情况下从 Java 操作 Access 数据库的更多相关文章

  1. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

    我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

  2. ruby-on-rails - rails 目前在重启后没有安装 - 2

    我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

  3. ruby - 默认情况下使选项为 false - 2

    这是在Ruby中设置默认值的常用方法:classQuietByDefaultdefinitialize(opts={})@verbose=opts[:verbose]endend这是一个容易落入的陷阱:classVerboseNoMatterWhatdefinitialize(opts={})@verbose=opts[:verbose]||trueendend正确的做法是:classVerboseByDefaultdefinitialize(opts={})@verbose=opts.include?(:verbose)?opts[:verbose]:trueendend编写Verb

  4. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  5. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  6. 使用 ACL 调用 upload_file 时出现 Ruby S3 "Access Denied"错误 - 2

    我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file

  7. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  8. 没有类的 Ruby 方法? - 2

    大家好!我想知道Ruby中未使用语法ClassName.method_name调用的方法是如何工作的。我头脑中的一些是puts、print、gets、chomp。可以在不使用点运算符的情况下调用这些方法。为什么是这样?他们来自哪里?我怎样才能看到这些方法的完整列表? 最佳答案 Kernel中的所有方法都可用于Object类的所有对象或从Object派生的任何类。您可以使用Kernel.instance_methods列出它们。 关于没有类的Ruby方法?,我们在StackOverflow

  9. ruby - 在不使用 RVM 的情况下在 Mac 上卸载和升级 Ruby - 2

    我最近决定从我的系统中卸载RVM。在thispage提出的一些论点说服我:实际上,我的决定是,我根本不想担心Ruby的多个版本。我只想使用1.9.2-p290版本而不用担心其他任何事情。但是,当我在我的Mac上运行ruby--version时,它告诉我我的版本是1.8.7。我四处寻找如何简单地从我的Mac上卸载这个Ruby,但奇怪的是我没有找到任何东西。似乎唯一想卸载Ruby的人运行linux,而使用Mac的每个人都推荐RVM。如何从我的Mac上卸载Ruby1.8.7?我想升级到1.9.2-p290版本,并且我希望我的系统上只有一个版本。 最佳答案

  10. ruby-on-rails - Rails 3,嵌套资源,没有路由匹配 [PUT] - 2

    我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle

随机推荐