数据库是oracle 9i 9.2.0.4,同事扔了个class12.jar(据说还是从另一项目复制过来8i的驱动),调了半天,发现所以配置都对了,但就是初始化时有问题。
2009-11-29 15:10:01 [WARN ] 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.springframework.orm.hibernate3.LocalSessionFactoryBean.newSessionFactory(LocalSessionFactoryBean.java:814)
at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:732)
at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:211)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1369)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1335)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:473)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
at java.security.AccessController.doPrivileged(Native Method)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:423)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:728)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:380)
at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)
at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)
at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4342)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
at org.apache.catalina.core.StandardService.start(StandardService.java:516)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
at org.apache.catalina.startup.Catalina.start(Catalina.java:578)
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.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
网上搜遍了就是没找出问题,后来就想着换驱动试试,到oracle下载了对应的驱动,9i 9.2.0.4, ojdbc14.jar 放回来居然还是这问题,看到它提供个debug的驱动,换了后发现没异常了。现在想了想,是不是oracle 9i 9.2.0.4,这个版本的驱动也是有问题的,结果下了个版本比这个稍高一点的,发现能用了。
分享到:
相关推荐
正确选择和使用JDBC驱动能确保Java应用与Oracle数据库之间通信的稳定性和效率,避免因版本不匹配引发的诸多问题。在实际项目中,务必根据具体环境和需求选择合适的驱动,并确保正确配置和使用。
ojdbc14-10.2.0.4.0.jar是Oracle公司发布的JDBC驱动版本之一,专为Oracle数据库10g版本设计。这个驱动包使得Java开发者能够利用Java Database Connectivity (JDBC) API来执行SQL语句、管理数据库事务以及进行数据...
然而,不同的数据库版本可能需要不同版本的JDBC驱动,这可能导致兼容性问题。在标题所提及的场景中,“加载同一类型但版本不同JDBC驱动”就是解决此类问题的关键。 当应用程序需要同时连接到多个相同类型的数据库,...
Oracle JDBC驱动是专门为Oracle数据库设计的JDBC驱动程序,它支持多种版本的Oracle数据库,并且能够提供高效的数据访问性能。Oracle JDBC驱动通常包括以下几个版本: - **Thin Driver**:这是一个纯Java驱动,不依赖...
ojdbc10.jar是Oracle JDBC驱动的一个版本,专门为JDK 10及更高版本设计。它包含了对Oracle 19c数据库的新特性和优化的支持,如新的SQL语法、性能改进以及对Java新特性的兼容。使用ojdbc10.jar时,确保你的开发环境...
Oracle JDBC驱动是Java应用程序连接到Oracle数据库的桥梁,但有时候由于各种原因,如代码错误、配置不当或驱动版本不兼容,可能会导致连接异常。 描述中的链接指向了一篇博客文章,虽然具体内容没有给出,但通常这...
- `dm8-oracle-jdbc16-wrapper.jar`:此文件可能是一个针对达梦8版本的Oracle兼容驱动,用于在Java应用中模拟Oracle JDBC驱动的行为,以便于迁移或兼容Oracle数据库的代码。 - `DmDictionary.jar`:这个文件可能是...
Oracle JDBC驱动程序是Oracle公司提供的特定于Oracle数据库的JDBC实现,使得Java开发者能够高效地执行SQL语句并处理结果。 本示例中的"Oracle jdbc 单例 工具类"着重讨论了单例模式的应用,单例模式是一种设计模式...
- 驱动版本与数据库版本的兼容性:确保使用的Oracle JDBC驱动与目标数据库版本匹配,避免因版本不兼容导致的问题。 - 错误处理:良好的错误处理机制是必须的,以便在连接失败或查询出错时能正确地捕获和处理异常。...
不同的Oracle版本可能需要对应版本的JDBC驱动,不匹配可能导致连接问题或性能下降。 6. **安全考虑**:在生产环境中,避免在代码中硬编码数据库凭据。可以使用环境变量、配置文件或者数据库连接池来管理这些敏感...
综上所述,JDBC驱动jar包是Java应用程序连接和操作数据库的关键组件,不同的数据库厂商提供了对应的JDBC驱动,如sqlserver.jar、mysql-connector-java.jar和ojdbc.jar,以支持与SQL Server、MySQL和Oracle数据库的...
要充分运用UCP和语句池,开发者需要正确设置开发环境,包括安装JDK 1.6及以上版本、支持JDK 1.6的Oracle JDBC瘦驱动程序,以及Oracle通用连接池库(UCP)。此外,还需熟悉UCP的配置参数,如最大连接数、最小连接数等...
1. **ojdbc6-11.2.0.3.jar**: 这是Oracle JDBC驱动的一个特定版本,适用于Oracle数据库11g Release 2。它包含了Oracle JDBC Driver ( Thin) 和 Oracle Universal Connection Pool (UCP)。JDBC Thin驱动是一种轻量级...
Oracle JDBC驱动程序分为四种类型: 1. ** Thin Driver (ojdbcXXX.jar) **:这是一个轻量级的驱动,不需要Oracle客户端软件。它直接通过网络与Oracle服务器通信,支持64位和32位操作系统。适用于分布式应用或远程...
* 使用 classes12.jar 文件作为 JDBC 驱动,因为 Oracle8 以上的版本都需要使用这个文件。 * 正确设置 Windows 的 classpath 和 Jbuilder 中的 Enterprise Setup、Configure Libraries,将 classes12.jar 路径正确...
- **驱动兼容性**:Oracle JDBC驱动与数据库版本之间可能存在兼容性问题,确保驱动版本与数据库服务器版本匹配。 以上是使用Java的JDBC以sys用户连接Oracle数据库的基本流程和关键点,实际开发中可能还需要根据具体...
最后,dm8-oracle-jdbc16-wrapper.jar可能是一个适配器或包装器,用于使达梦数据库能够与Oracle数据库的JDBC驱动兼容,或许是为了在某些场景下提供跨平台的数据迁移或互操作性。 总的来说,这个压缩包提供了全面的...
Oracle的JDBC驱动程序支持多国语言,通过调整驱动的配置,可以处理不同语言的数据。例如,Oracle Thin Driver可以通过设置Properties对象中的charset属性来改变字符编码。 六、国际化与本地化 为了实现真正的多国...