有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

使用jboss工具/hibernate配置连接到数据库时发生java错误

我正在尝试使用jboss工具hibernate代码生成为postgresql数据库中的表生成DAO和hibernate映射。我已经设置了hibernate配置,但当我尝试连接时,出现以下错误:

java.lang.NoSuchFieldError: INSTANCE
    at org.hibernate.type.StandardBasicTypes.<clinit>(StandardBasicTypes.java:54)
    at org.hibernate.spatial.dialect.postgis.PostgisDialect.registerTypesAndFunctions(PostgisDialect.java:55)
    at org.hibernate.spatial.dialect.postgis.PostgisDialect.<init>(PostgisDialect.java:42)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at java.lang.Class.newInstance(Unknown Source)
    at org.hibernate.dialect.resolver.DialectFactory.constructDialect(DialectFactory.java:157)
    at org.hibernate.dialect.resolver.DialectFactory.buildDialect(DialectFactory.java:109)
    at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:146)
    at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2163)
    at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2155)
    at org.hibernate.console.ConsoleConfiguration$6.execute(ConsoleConfiguration.java:430)
    at org.hibernate.console.execution.DefaultExecutionContext.execute(DefaultExecutionContext.java:63)
    at org.hibernate.console.ConsoleConfiguration.execute(ConsoleConfiguration.java:107)
    at org.hibernate.console.ConsoleConfiguration.getSettings(ConsoleConfiguration.java:428)
    at org.hibernate.eclipse.console.workbench.LazyDatabaseSchemaWorkbenchAdapter$2.execute(LazyDatabaseSchemaWorkbenchAdapter.java:119)
    at org.hibernate.console.execution.DefaultExecutionContext.execute(DefaultExecutionContext.java:63)
    at org.hibernate.console.ConsoleConfiguration.execute(ConsoleConfiguration.java:107)
    at org.hibernate.eclipse.console.workbench.LazyDatabaseSchemaWorkbenchAdapter.readDatabaseSchema(LazyDatabaseSchemaWorkbenchAdapter.java:115)
    at org.hibernate.eclipse.console.workbench.LazyDatabaseSchemaWorkbenchAdapter.getChildren(LazyDatabaseSchemaWorkbenchAdapter.java:65)
    at org.hibernate.eclipse.console.workbench.BasicWorkbenchAdapter.fetchDeferredChildren(BasicWorkbenchAdapter.java:106)
    at org.eclipse.ui.progress.DeferredTreeContentManager$1.run(DeferredTreeContentManager.java:235)
    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:53)

我在第54行查看了StandardBasicTypes,它的内容是public static final BooleanType BOOLEAN = BooleanType.INSTANCE;,我遵循了BooleanType字段。类BooleanType中确实存在的实例

我使用的是hibernate-core-4.1.8。最终的jar,hibernate-spatial-4.0-M1。在我的hibernate配置中,“hibernate版本”是“4.0”


共 (1) 个答案

  1. # 1 楼答案

    这个问题与我的hibernate配置有关,特别是驱动程序和方言。最初,我

    <property name="hibernate.connection.driver_class">org.postgis.DriverWrapper</property>
    <property name="hibernate.dialect">org.hibernate.spatial.dialect.postgis.PostgisDialect</property>
    

    我收到了上面问题中的错误堆栈跟踪。我把这些属性改成了

    <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
    <property name="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</property>
    

    并且能够通过hibernate工具连接到数据库。如果有人关心的话,我创建了一个JIRA here来跟踪问题,如果有人希望能够对地理空间对象使用hibernate工具