我得到以下
java.lang.ClassCastException: com.mchange.v2.c3p0.impl.NewProxyConnection
执行以下代码时。你能帮我解决一下吗?
ComboPooledDataSource connPool = new ComboPooledDataSource();
connPool .setJdbcUrl(PropertyReader.getSystemProperty(DB_URL));
connPool .setUser(PropertyReader.getSystemProperty(DB_USER));
connPool .setPassword(Decryption.getDecryptedPwd(DB_PASSWORD));
connPool .setMaxPoolSize(MAX_POOL_SIZE);
connPool .setMaxIdleTime(MAX_IDLE_TIME);
connPool .setMinPoolSize(MIN_POOL_SIZE);
connPool .setMaxAdministrativeTaskTime(15);
java.sql.Connection conn = connPool.getConnection();
oracle.sql.CLOB c = CLOB.createTemporary(conn, false, CLOB.DURATION_SESSION);
Writer writer = c.setCharacterStream(0L);
writer.write(String.valueOf(pNoListDelimited).toCharArray());
writer.flush();
writer.close();
异常堆栈跟踪
java.lang.ClassCastException: com.mchange.v2.c3p0.impl.NewProxyConnection
at oracle.sql.CLOB.createTemporary(CLOB.java:676)
at oracle.sql.CLOB.createTemporary(CLOB.java:640)
……
…..
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269)
at java.util.concurrent.FutureTask.run(FutureTask.java:123)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:651)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:676)
at java.lang.Thread.run(Thread.java:595)
答案 0 :(得分:5)
您正在使用特定于Oracle的API,期望您的Connection成为特定的Oracle Connection类。但您正在使用的Connection是c3p0代理连接,而不是Oracle Connection类。
如果您想使用特定于Oracle的API,您可以选择以下几种方法:
答案 1 :(得分:3)
展开您的c3p0代理连接
java.sql.Connection conn = connPool.getConnection();
conn = conn.unwrap(OracleConnection.class);
确保正确关闭连接。
答案 2 :(得分:1)
最简单的方法:
添加此依赖项:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>4.1.3.RELEASE</version>
</dependency>
创建一个C3P0NativeJdbcExtractor:
public class C3P0NativeJdbcExtractorImpl extends C3P0NativeJdbcExtractor {
public Connection getNativeConnection(Connection con) throws SQLException {
return doGetNativeConnection(con);
}
}
将原始连接转换为nativeConnection:
Connection nativeCon = new C3P0NativeJdbcExtractorImpl().getNativeConnection(ps.getConnection());
使用nativeCon代替conn:
oracle.sql.CLOB c = CLOB.createTemporary(nativeCon, false, CLOB.DURATION_SESSION);