JdbcTemplate 在使用连接池的情况下,数据库连接仍超出最大回话数可能的原因

在使用spring框架的时候,会经常用到jdbcTemplate,而可能习惯性的每次创建都是通过

ApplicationContext act = new  ClassPathXmlApplicationContext("application-context.xml");

JdbcTemplate jdbcTemplate = (JdbcTemplate) act.getBean("jdbcTemplate");

这样来创建的。

这种方式在连接数据库次数小时,好像并不会出现问题,但是在经常操作库的时候就会发现一会  数据库连接就超出了最大回话数。


解决方式:对ApplicationContext使用单列

/**
 * 
* @ClassName: ApplicationBean 
* @Description: 获取ApplicationContext 实例
* @author wxd
* @date 2017年6月23日 上午1:36:06 
*
 */
public class ApplicationBean {
	static private ApplicationContext ac = null;
	 static {
	        ac = new ClassPathXmlApplicationContext("application-context.xml");
	    }
	 
	    private ApplicationBean() {
	    }
	 /**
	  * 
	 * @Title: getAc 
	 * @Description: 获取ApplicationContext对象
	 * @param @return     
	 * @return ApplicationContext     
	 * @date 2017年6月23日 上午1:37:58 
	 * @author wxd
	 * @throws
	  */
	    public static ApplicationContext getAc() {
	        return ac;
	    }
}
然后在使用时只需要通过

	ApplicationContext act = ApplicationBean.getAc();
    	JdbcTemplate jdbcTemplate = (JdbcTemplate) act.getBean("jdbcTemplate");
这样就解决了以上问题

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值