c3p0连接oracle的问题

发布于 2021-12-02 19:57:37 字数 900 浏览 915 评论 12

我的框架是Spring没有使用hibernate,数据库连接使用的是c3p0最新版本:c3p0-0.9.5.2.jar同时与oracle相关jar包c3p0-oracle-thin-extras-0.9.5.2.jar已导入,mchange-commons-java-0.2.11.jar也导入,调用oracle存储过程,如果传入参数是字符串没问题,可以正常连接数据库并正常调用,但是传入的是List在list与oracle类型转换的时候报错:com.mchange.v2.c3p0.impl.NewProxyConnection cannot be cast to oracle.jdbc.OracleConnection

报错的语句:StructDescriptor structdesc = StructDescriptor.createDescriptor(oracleObj, conn);

这是oracle.sql.StructDescriptor里面的构造函数

但是在spring使用自带的dataSource配置:

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 是没问题的,使用

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"就有问题,是不是C3P0的问题还是我有哪里配置不正确?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(12

吃颗糖壮壮胆 2021-12-03 22:34:17

java传参list的时候,oralce需要使用 游标类型来接收。

飘然心甜 2021-12-03 22:34:15

回复
搞定了,getConnect()的问题,connection需要先转换

伪装你 2021-12-03 22:33:58

引用来自“求是科技”的评论

druid与oracle连接的jar包都是从maven上下载的吗?我觉得你这里很有可能是jar包的问题。另外自己的ip尽量写成localhost或127.0.0.1,不要写成192.168.2.67这种。

陌若浮生 2021-12-03 22:33:34

哦 不对。你这是传输list的问题,应该属于用法问题,你换成map试下,我记得曾今我们的解决方案是 循环list生成一个字符串 传进去,进去后解析出来。

https://my.oschina.net/u/2312022/blog/481180

冬天旳寂寞 2021-12-03 22:26:37

druid与oracle连接的jar包都是从maven上下载的吗?我觉得你这里很有可能是jar包的问题。另外自己的ip尽量写成localhost或127.0.0.1,不要写成192.168.2.67这种。

野心澎湃 2021-12-03 22:20:04

换了,也是一样的问题

彼岸花ソ最美的依靠 2021-12-03 22:19:21

引用来自“求是科技”的评论

<!-- 配置master数据源 -->
	<bean id="masterDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
		<property name="driverClassName" value="${driverClassName}"></property>
		<property name="url" value="${master_jdbc_url}"></property>
		<property name="username" value="${master_jdbc_username}"></property>
		<property name="password" value="${master_jdbc_password}"></property>
	</bean>

终止放荡 2021-12-03 22:11:36
<!-- 配置master数据源 -->
	<bean id="masterDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
		<property name="driverClassName" value="${driverClassName}"></property>
		<property name="url" value="${master_jdbc_url}"></property>
		<property name="username" value="${master_jdbc_username}"></property>
		<property name="password" value="${master_jdbc_password}"></property>
	</bean>

悟红尘 2021-12-03 20:27:45

这个常用不,现在用的多不?很久没搞java了。对行情不是很了解

梦中楼上月下 2021-12-03 18:56:50

web 80%以上都采用这个连接池

为你鎻心 2021-12-03 17:08:02

换成ali的吧,com.alibaba.druid.pool.DruidDataSource 稳定可靠,用过c3p0,出现过很多问题,尤其是有时候连接的上,有时候连不上。

眼泪淡了忧伤 2021-12-02 23:20:30

两个不同的包,肯定有不一样的,好好看下

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文