C3P0可以连接oracle吗?如果可以怎么配置呢。

C3P0可以连接oracle吗?如果可以怎么配置呢。

C3P0可以连接oracle吗?如果可以怎么改配置文件呢。

正在回答

登陆购买课程后可参与讨论,去登陆

2回答

同学你好,C3P0可以连接Oracle,主要是修改配置文件中的driverClass和jdbcUrl。将driverClass和jdbcUrl修改为Oracle的,参考如下:

<property name="driverClass">oracle.jdbc.driver.OracleDriver</property>
<property name="jdbcUrl">jdbc:oracle:thin:@地址:端口:表名</property>

如果我的回答解决了你的疑惑,请采纳。祝:学习愉快~

  • 萧飞_ 提问者 #1
    看下我的回复 老师。还是报错 Caused by: java.sql.SQLException: No suitable driver java.sql.SQLException: Connections could not be acquired from the underlying database!
    2019-04-17 21:39:41
  • 好帮手慕阿满 回复 提问者 萧飞_ #2
    同学你好,报错提示需要合适的驱动。mysql需要mysql的驱动,也就是mysql的jar包,Oracle也需要Oracle的jar包。问一下同学的项目中有Oracle的jar包吗?如果没有,需要先添加Oracle的jar包。祝:学习愉快~
    2019-04-18 09:35:40
提问者 萧飞_ 2019-04-17 21:38:25
<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
    <named-config name="oracle">
        <!-- 配置数据库用户名 -->
        <property name="user">alex</property>
        <!-- 配置数据库密码 -->
        <property name="password">alex</property>
        <!-- 配置数据库链接地址 -->
        <property name="jdbcUrl">jdbc:oracle:thin:@localhost:1521:orcl</property>
        <!-- 配置数据库驱动 -->
        <property name="driverClass">oracle.jdbc.driver.OracleDriver</property>
        <!-- 数据库连接池一次性向数据库要多少个连接对象 -->
        <property name="acquireIncrement">20</property>
        <!-- 初始化连接数 -->
        <property name="initialPoolSize">10</property>
        <!-- 最小连接数 -->
        <property name="minPoolSize">5</property>
        <!--连接池中保留的最大连接数。Default: 15 -->
        <property name="maxPoolSize">30</property>
        <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements 属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default:0 -->
        <property name="maxStatements">0</property>
        <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
        <property name="maxStatementsPerConnection">0</property>
        <!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能 通过多线程实现多个操作同时被执行。Default:3 -->
        <property name="numHelperThreads">3</property>
        <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
        <property name="propertyCycle">3</property>
        <!-- 获取连接超时设置 默认是一直等待单位毫秒 -->
        <property name="checkoutTimeout">1000</property>
        <!--每多少秒检查所有连接池中的空闲连接。Default: 0 -->
        <property name="idleConnectionTestPeriod">3</property>
        <!--最大空闲时间,多少秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
        <property name="maxIdleTime">10</property>
        <!--配置连接的生存时间,超过这个时间的连接将由连接池自动断开丢弃掉。当然正在使用的连接不会马上断开,而是等待它close再断开。配置为0的时候则不会对连接的生存时间进行限制。 -->
        <property name="maxIdleTimeExcessConnections">5</property>
        <!--两次连接中间隔时间,单位毫秒。Default: 1000 -->
        <property name="acquireRetryDelay">1000</property>
        <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。Default: null -->
        <property name="automaticTestTable">Test</property>
        <!-- 获取connnection时测试是否有效 -->
        <property name="testConnectionOnCheckin">true</property>
    </named-config>
</c3p0-config>

老师看下我配置文件有问题吗,还是报错

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师