Установление соединения из Java для доступа 2010 64bit - PullRequest
0 голосов
/ 13 ноября 2011

Пройдя несколько уроков и постов в блоге, я безуспешно пытался установить соединение из Java в базу данных Microsoft Access.мои системные спецификации:

win 7 [64 бит] odbcad32.ese [64 бит] access 2010 [64 бит] 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 -> ok

  4. применить

  5. ок

теперь, когда я пытаюсь запустить свое приложение, это ошибка , что яполучение,

    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 голосов
/ 16 июля 2012

Согласно этому блогу, вы должны либо запустить 32-битную версию Java, либо использовать 64-битную версию офисных драйверов:

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

0 голосов
/ 13 декабря 2011

Вы пытались изменить строку подключения на:

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

Похоже, это разница между 32- и 64-битной версиями драйвера. Я могу подключиться, используя эту строку в той же среде.

(Теперь мне просто нужно выяснить, что происходит с ошибкой «java.sql.SQLException: [Microsoft] [ODBC Driver Manager] Недопустимая длина строки или буфера», которую я получаю ...)

...