将 T4CConnection 转换为 OracleConnection 时出错

Gur*_*kha 5 java oracle11g weblogic12c

Spring 应用程序使用 JNDI 查找来获取数据源,如下所示:

   @Bean(name = "dataSource1", destroyMethod = StringUtils.EMPTY)
    public DataSource dataSource() {
        final JndiDataSourceLookup lookup = new JndiDataSourceLookup();
        lookup.setResourceRef(true);

        return lookup.getDataSource(this.environment.getProperty(Constants.DB_JNDI_NAME_ES));
    }
Run Code Online (Sandbox Code Playgroud)

并从数据源获取连接如下:

@Autowired
@Qualifier("dataSource1")
private DataSource ds;



 Connection conn = null;
 conn = this.ds.getConnection();
Run Code Online (Sandbox Code Playgroud)

但是当我将该连接传递给 StructDescriptor 时,它会抛出 classCastException 如下:

StructDescriptor desc1 = StructDescriptor.createDescriptor("MSAF_DBA.AMOUNT_DUE_OBJ",conn);

java.lang.ClassCastException: weblogic.jdbc.wrapper.PoolConnection_oracle_jdbc_driver_T4CConnection cannot be cast to oracle.jdbc.OracleConnection
    at oracle.sql.StructDescriptor.createDescriptor(StructDescriptor.java:101)
    at oracle.sql.StructDescriptor.createDescriptor(StructDescriptor.java:72)
    at com.ceiwc.es.policyholder.dao.PolicyHolderDaoImpl.getAmountDue(PolicyHolderDaoImpl.java:290)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
Run Code Online (Sandbox Code Playgroud)

我的理解是getConnection()回报T4CConnection,其中的OracleConnection是必需的。尝试了几种方法来获得oracleConnection但似乎无法获得它。任何帮助,将不胜感激。

Dis*_*ing 5

我相信这与您的 war/ear 文件的内容有关。请勿打包在 Oracle 驱动程序 .jar 文件中。

具体来说,如果您ojdbc6.jar的 war 文件(或等效文件)中有它会导致冲突。可以使用该 jar 进行编译,但您不希望在类路径中使用它,因为默认情况下它已经在 Weblogic 类路径中。

有关类似信息,请参阅这些链接:此处此处

  • 如果您使用 Maven,请将这个 jar _provided_。此外,在管理控制台中,您需要**取消选择**连接池/高级数据源下的 _Wrap Data Types_ 复选框。 (3认同)