建立从java到访问2010 64bit的连接

时间:2011-11-13 09:22:22

标签: java ms-access database-connection jdbc-odbc file-not-found

经过几个教程和博客文章后,我试图建立从java到微软访问数据库的连接失败。我的系统规格是

  

win 7 [64 bit] odbcad32.ese [64 bit] access 2010 [64 bit] jre6 [64   比特]

我为建立连接而编写的代码

        public Connection makeConn() throws ClassNotFoundException, SQLException
        {
           Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
           conn = DriverManager.getConnection("jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=C:\\Users\\ARIFAH\\Desktop\\sampleDb.mdb");

           return conn;
        }
数据源中的

[odbc] --- [位于路径%windir%\ system32 \ odbcad32.exe ]

我执行了以下任务

  1. USER DSN TAB ADD-> Microsoft Access驱动程序(* .mdb,* .accdb)[文件ACEODBC.dll] - >完成

  2. 数据源名称:TestDriver; 描述:访问2010 64位的测试驱动程序;

  3. 数据库 - >选择 - >浏览:C:\ Users \ ARIFAH \ Desktop \ sampleDb.mdb - >确定

  4. 应用

  5. 确定

  6. 现在当我尝试运行我的应用程序时,这是我得到的错误

        java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver] Could not find file '(unknown)'.
                at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source)
            at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source)
            at sun.jdbc.odbc.JdbcOdbc.SQLDriverConnect(Unknown Source)
            at sun.jdbc.odbc.JdbcOdbcConnection.initialize(Unknown Source)
            at sun.jdbc.odbc.JdbcOdbcDriver.connect(Unknown Source)
            at java.sql.DriverManager.getConnection(Unknown Source)
            at java.sql.DriverManager.getConnection(Unknown Source)
            at dataBase.connection.makeConn(connection.java:22)
            at newmodulewizrd.ui.App.<init>(App.java:32)
            at archetypedcomponent.commands.newModuleHandler.execute(newModuleHandler.java:39)
            at org.eclipse.ui.internal.handlers.HandlerProxy.execute(HandlerProxy.java:294)
            at org.eclipse.core.commands.Command.executeWithChecks(Command.java:476)
            at org.eclipse.core.commands.ParameterizedCommand.executeWithChecks(ParameterizedCommand.java:508)
            at org.eclipse.ui.internal.handlers.HandlerService.executeCommand(HandlerService.java:169)
            at org.eclipse.ui.internal.handlers.SlaveHandlerService.executeCommand(SlaveHandlerService.java:241)
            at org.eclipse.ui.internal.handlers.SlaveHandlerService.executeCommand(SlaveHandlerService.java:241)
            at org.eclipse.ui.menus.CommandContributionItem.handleWidgetSelection(CommandContributionItem.java:770)
            at org.eclipse.ui.menus.CommandContributionItem.access$10(CommandContributionItem.java:756)
            at org.eclipse.ui.menus.CommandContributionItem$5.handleEvent(CommandContributionItem.java:746)
            at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
            at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1003)
            at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3910)
            at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3503)
            at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2405)
            at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2369)
            at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2221)
            at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:500)
            at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
            at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:493)
            at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
            at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:113)
            at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:194)
            at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:110)
            at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:79)
            at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:368)
            at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179)
            at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
            at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
            at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
            at java.lang.reflect.Method.invoke(Unknown Source)
            at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:559)
            at org.eclipse.equinox.launcher.Main.basicRun(Main.java:514)
            at org.eclipse.equinox.launcher.Main.run(Main.java:1311)
            at org.eclipse.equinox.launcher.Main.main(Main.java:1287)
    

    有人可以帮忙吗?

2 个答案:

答案 0 :(得分:0)

您是否尝试将连接字符串更改为:

jdbc:odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=C:\\Users\\ARIFAH\\Desktop\\sampleDb.mdb  

这似乎是32位和64位版本驱动程序之间的差异。我可以使用相同的环境使用该字符串进行连接。

(现在我只需要弄清楚“java.sql.SQLException:[Microsoft] [ODBC驱动程序管理器]无效的字符串或缓冲区长度”正在发生的事情“我得到的错误......)

答案 1 :(得分:0)

根据此博客,您要么必须运行32位版本的Java,要么使用64位版本的办公室驱动程序:

http://www.selikoff.net/2011/07/26/connecting-to-ms-access-file-via-jdbc-in-64-bit-java/