簡體   English   中英

在OSGI中使用ucanaccess時出錯

[英]error using ucanaccess in osgi

我已經閱讀了UcanAccess簡介問題,但無法使驅動程序在OSGi / RCP應用程序中工作。 我認為這是一個類加載器問題,但不知道如何解決。

相關代碼段,它在第二行失敗。 MDB存在,使用UcanAccess的非OSGi Java應用程序可以成功打開它。

Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
con = DriverManager.getConnection("jdbc:ucanaccess://" + FILENAME);

我得到以下異常:

**4302 INFO  org.eclipse.ecf.osgi.services.remoteserviceadmin - [S:{org.osgi.framework.hooks.service.EventListenerHook}={service.id=274, service.bundleid=86, service.scope=singleton}] ServiceEvent REGISTERED
net.ucanaccess.jdbc.UcanaccessSQLException: user lacks privilege or object not found java.lang.ClassNotFoundException: net.ucanaccess.converters.Functions cannot be found by org.hsqldb.hsqldb_2.3.1 net.ucanaccess.converters.Functions in statement [CREATE FUNCTION SLN(par0 DOUBLE,par1 DOUBLE,par2 DOUBLE) RETURNS DOUBLE  LANGUAGE JAVA DETERMINISTIC NO SQL  EXTERNAL NAME 'CLASSPATH:net.ucanaccess.converters.Functions.sln']
    at net.ucanaccess.jdbc.UcanaccessDriver.connect(UcanaccessDriver.java:247)
    at java.sql.DriverManager.getConnection(DriverManager.java:664)
    at java.sql.DriverManager.getConnection(DriverManager.java:270)
    at com.easa.motordb.load.HornerLoad.execute(HornerLoad.java:26)
    at org.eclipse.ui.internal.handlers.HandlerProxy.execute(HandlerProxy.java:294)
    at org.eclipse.ui.internal.handlers.E4HandlerProxy.execute(E4HandlerProxy.java:90)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.eclipse.e4.core.internal.di.MethodRequestor.execute(MethodRequestor.java:55)
    at org.eclipse.e4.core.internal.di.InjectorImpl.invokeUsingClass(InjectorImpl.java:247)
    at org.eclipse.e4.core.internal.di.InjectorImpl.invoke(InjectorImpl.java:229)
    at org.eclipse.e4.core.contexts.ContextInjectionFactory.invoke(ContextInjectionFactory.java:132)
    at org.eclipse.e4.core.commands.internal.HandlerServiceHandler.execute(HandlerServiceHandler.java:149)
    at org.eclipse.core.commands.Command.executeWithChecks(Command.java:499)
    at org.eclipse.core.commands.ParameterizedCommand.executeWithChecks(ParameterizedCommand.java:508)
    at org.eclipse.e4.core.commands.internal.HandlerServiceImpl.executeHandler(HandlerServiceImpl.java:210)
    at org.eclipse.e4.ui.workbench.renderers.swt.HandledContributionItem.executeItem(HandledContributionItem.java:825)
    at org.eclipse.e4.ui.workbench.renderers.swt.HandledContributionItem.handleWidgetSelection(HandledContributionItem.java:701)
    at org.eclipse.e4.ui.workbench.renderers.swt.HandledContributionItem.access$6(HandledContributionItem.java:685)
    at org.eclipse.e4.ui.workbench.renderers.swt.HandledContributionItem$4.handleEvent(HandledContributionItem.java:613)
    at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84)
    at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4353)
    at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1061)
    at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4172)
    at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3761)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$9.run(PartRenderingEngine.java:1151)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1032)
    at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:148)
    at org.eclipse.ui.internal.Workbench$5.run(Workbench.java:636)
    at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:332)
    at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:579)
    at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150)
    at com.easa.acmotor.base.Application.start(Application.java:24)
    at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
    at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:380)
    at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:235)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:648)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:603)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1465)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1438)
Caused by: java.sql.SQLSyntaxErrorException: user lacks privilege or object not found java.lang.ClassNotFoundException: net.ucanaccess.converters.Functions cannot be found by org.hsqldb.hsqldb_2.3.1 net.ucanaccess.converters.Functions in statement [CREATE FUNCTION SLN(par0 DOUBLE,par1 DOUBLE,par2 DOUBLE) RETURNS DOUBLE  LANGUAGE JAVA DETERMINISTIC NO SQL  EXTERNAL NAME 'CLASSPATH:net.ucanaccess.converters.Functions.sln']
    at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
    at org.hsqldb.jdbc.JDBCUtil.sqlException(Unknown Source)
    at org.hsqldb.jdbc.JDBCStatement.fetchResult(Unknown Source)
    at org.hsqldb.jdbc.JDBCStatement.executeUpdate(Unknown Source)
    at net.ucanaccess.converters.LoadJet.exec(LoadJet.java:1258)
    at net.ucanaccess.converters.LoadJet.access$0(LoadJet.java:1253)
    at net.ucanaccess.converters.LoadJet$FunctionsLoader.createFunctions(LoadJet.java:156)
    at net.ucanaccess.converters.LoadJet$FunctionsLoader.addFunctions(LoadJet.java:151)
    at net.ucanaccess.converters.LoadJet$FunctionsLoader.loadMappedFunctions(LoadJet.java:178)
    at net.ucanaccess.converters.LoadJet$FunctionsLoader.access$2(LoadJet.java:177)
    at net.ucanaccess.converters.LoadJet.loadDB(LoadJet.java:1310)
    at net.ucanaccess.jdbc.UcanaccessDriver.connect(UcanaccessDriver.java:236)
    ... 48 more
Caused by: org.hsqldb.HsqlException: user lacks privilege or object not found java.lang.ClassNotFoundException: net.ucanaccess.converters.Functions cannot be found by org.hsqldb.hsqldb_2.3.1 net.ucanaccess.converters.Functions
    at org.hsqldb.error.Error.error(Unknown Source)
    at org.hsqldb.Routine.getMethods(Unknown Source)
    at org.hsqldb.Routine.getMethod(Unknown Source)
    at org.hsqldb.Routine.resolveReferences(Unknown Source)
    at org.hsqldb.Routine.resolve(Unknown Source)
    at org.hsqldb.StatementSchema.getResult(Unknown Source)
    at org.hsqldb.StatementSchema.execute(Unknown Source)
    at org.hsqldb.Session.executeCompiledStatement(Unknown Source)
    at org.hsqldb.Session.executeDirectStatement(Unknown Source)
    at org.hsqldb.Session.execute(Unknown Source)
    ... 58 more
Caused by: java.lang.ClassNotFoundException: net.ucanaccess.converters.Functions cannot be found by org.hsqldb.hsqldb_2.3.1
    at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:432)
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:345)
    at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:337)
    at org.eclipse.osgi.internal.loader.ModuleClassLoader.loadClass(ModuleClassLoader.java:160)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    ... 67 more

我已采取的步驟:

  1. 從ucanaccess創建一個插件/捆綁
  2. Require-Bundle:清單中的org.hsqldb.hsqldb; bundle-version =“ 2.3.1”
  3. 使它成為注冊伙伴(Eclipse-BuddyPolicy:已注冊)
  4. 使我的捆綁軟件知道(Eclipse-RegisterBuddy:ucanaccess)
  5. 確保所有捆綁包均已自動啟動(ucanaccess,hsql和我的捆綁包)

我最初僅在新捆綁包中包括ucanaccess.jar文件,並將其他jar文件放在目標平台/插件列表中。

解決方案是使用所有UcanAccess所需的jar文件(ucanaccess-2.0.9.4.jar,commons-lang-2.6.jar,commons-logging-1.1.1.jar,hsqldb.jar,jackcess-2.0.8)創建新的捆綁包。 。罐)。

您已經忽略了將數據庫用戶名和密碼中的空“”放入getConnection中。 試試這個代碼:

con = DriverManager.getConnection("jdbc:ucanaccess://" + FILENAME, "", "");

您的問題現在可能已經解決了,但是對於那些可以解決其他問題的人:取消限制。

Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");

它對我來說效果很好。 我確實使用JDK 1.8和Jackcess 2.08年

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM