标签:row use tor height load case inpu wrapper 关闭
用户每次请求都会建立一次数据库连接,并且数据库创建连接会消耗相对大的资源和时间。
如果针对于个别的工具或者是大量的代码测试甚至系统运行,对数据库操作次数频繁,极大的占用数据库资源,有可能会发生宕机或者内存溢出的现象。
而在大多的项目中,常常用到阿里巴巴开源的数据库连接池框架,准确来说它不仅仅包括数据库连接池,
原因其实很简单,在Spring框架的配置文件中仅仅一个配置datasource就可以使用Druid了
我们对Druid不加探讨,实现自定义的数据库连接池,来对数据进行处理。
在pom文件中引人数据库所需要的jar包,这里不一一介绍。
建立JdbcConnectionsPool类实现数据源接口DataSource重写其getConnection方法
对方法进行进一步封装
测试方法
输出结果:
异常处理
代码如下
在使用动态代理增强Connection连接对象的close方法时,我碰到了如题所示的异常。通过搜索我发现这个异常出现的原因在于我使用的mysql数据库驱动的问题,由于数据库驱动不同,Connection.class.getInterfaces()返回的结果也不同,它返回的是一个Class[]数组,然而此数组的第一个元素必须是Connection才能把创建的代理类转为Connection对象,否则就会报错。
所以这里我们可以采取一个替代方式替换Connection.class.getInterfaces(),即new Class[] { Connection.class },这样无论数据库驱动是什么版本的驱动,都能保证这个类型转换不出错。
欢迎关注公众号
标签:row use tor height load case inpu wrapper 关闭
原文地址:https://www.cnblogs.com/zhaixingzhu/p/12569184.html