23:56:01,281  INFO org.hibernate.tool.hbm2ddl.SchemaExport:268 - schema export complete
23:56:01,453  WARN org.hibernate.cfg.SettingsFactory:126 - Could not obtain connection metadata
java.sql.SQLException: 不支持的特性
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:269)
at oracle.jdbc.dbaccess.DBError.throwUnsupportedFeatureSqlException(DBError.java:689)
at oracle.jdbc.OracleDatabaseMetaData.supportsGetGeneratedKeys(OracleDatabaseMetaData.java:4180)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:123)
at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2119)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2115)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1339)
at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:867)
at com.sunguoan.hibernate.modelTest.TestTree.beforeClass(TestTree.java:21)
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.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:27)
at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:38)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
因为什么出这个异常?怎样处理?

解决方案 »

  1.   

    没见过,也不了解oracle。
    我猜是不是sql语句中对日期格式用函数转换时出了错?
      

  2.   

    你看看你指定的数据库方言?或者你写的sql语句不符合Oracle标准
      

  3.   

    肯定是 sql语句不精确 造成的,语句可以先运行通过了 在用。要是sql语句可以跑起来,但代码中的sql有变量的话,那就是变量值不和sql胃口了,自己debug 定位下,看问题在哪里要定位异常,光看这个是不行的,报的异常不一定能定位你的bug所在
      

  4.   

    sql语句?
    我用的是hibernate。
    、我是新手,刚接触java三个月
      

  5.   

    oracle.jdbc.OracleDatabaseMetaData.supportsGetGeneratedKeys(OracleDatabaseMetaData.java:4180)这句话看到了吗?是不是Hibernate反转时你什么选错了,Oracle没有自增键的。
      

  6.   

    WARN org.hibernate.cfg.SettingsFactory:126 - Could not obtain connection metadata
    java.sql.SQLException: 不支持的特性
    只是警告
    当然不会影响程序