spring对oracle.jdbc.pool.OracleDataSource连接不关闭的探讨

近日,为了提高程序执行效率,使用存储过程将批量记录写入数据库。
在代码实现中,遇到几个问题:
将多条记录数据,封装成Oracle所需的ARRAY类型时,用到Connection。我所使用的数据连接,是由Spring配置org.apache.commons.dbcp.BasicDataSource生成连接的。从这一数据源中,从JdbcDaoSupport得到连接使用时,报对象造型错误。经跟踪,发现JdbcDaoSupport中得到的Connection,并不是Oracle数据库的连接类型。至此改用oracle.jdbc.pool.OracleDataSource提供数据源。

2 改用oracle.jdbc.pool.OracleDataSource后,存储过程调用正常。但在随后的压力测试中,发现频繁获取连接时,间断出现得不到连接的报错信息。经查找,问题出在Springoracle.jdbc.pool.OracleDataSource数据源的维护上,Spring使用完这个数据源提供的数据连接后并不进行关闭操作,改用org.apache.commons.dbcp.BasicDataSource没有这个问题。

       所以,oracle.jdbc.pool.OracleDataSource配置的数据连接源,需要显示的关闭连接。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring项目中使用阿里巴巴的Druid连接池来装载Oracle数据源,可以按照以下步骤进行: 1. 首先,在pom.xml文件中添加Druid和Oracle驱动的依赖: ``` <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.6</version> </dependency> <dependency> <groupId>com.oracle.jdbc</groupId> <artifactId>ojdbc8</artifactId> <version>19.7.0.0</version> </dependency> ``` 2. 在Spring配置文件中配置数据源: ``` <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/> <property name="url" value="jdbc:oracle:thin:@localhost:1521:ORCL"/> <property name="username" value="your_username"/> <property name="password" value="your_password"/> <property name="initialSize" value="5"/> <property name="maxActive" value="50"/> <property name="minIdle" value="5"/> <property name="maxWait" value="60000"/> <property name="validationQuery" value="SELECT 1 FROM DUAL"/> <property name="testWhileIdle" value="true"/> <property name="timeBetweenEvictionRunsMillis" value="60000"/> <property name="minEvictableIdleTimeMillis" value="300000"/> <property name="poolPreparedStatements" value="true"/> <property name="maxPoolPreparedStatementPerConnectionSize" value="20"/> </bean> ``` 其中,initialSize是连接池启动时创建的初始化连接数;maxActive是连接池最大连接数;minIdle是连接池最小连接数;maxWait是获取连接的最大等待时间;validationQuery是用来检测连接是否有效的SQL语句;testWhileIdle是空闲时是否进行连接检测;timeBetweenEvictionRunsMillis是定时检查连接池中空闲连接的间隔时间;minEvictableIdleTimeMillis是连接池中连接最小空闲时间;poolPreparedStatements是是否缓存PreparedStatement;maxPoolPreparedStatementPerConnectionSize是单个连接池中最大的缓存Statement数目。 3. 在DAO层中使用该数据源: ``` @Repository public class UserDaoImpl implements UserDao { @Autowired private DataSource dataSource; private JdbcTemplate jdbcTemplate; @PostConstruct public void init() { jdbcTemplate = new JdbcTemplate(dataSource); } // ... } ``` 在DAO实现类中通过@Autowired注入Druid数据源,并在@PostConstruct注解的init()方法中创建JdbcTemplate对象,即可使用该数据源进行数据库操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值