JDBC连接池(下)

第三个版本

  第一个改变的地方就是在util中新定义了三个需要关闭的变量这里框中设成私有为了安全,静态为了类名能直接调用,但是别加final,用了final成自定义常量,下面就用不了刚开始置为空,在封装的close方法中只要不是null说明用过了就可以关闭。

  第二个改变的是我们发现增删改的代码是差不多的可以封装成一个方法,差距就在于增删改根据条件的不同,问号的数量不同罢了。所以我们引入了可变参数可变参数也叫可变数组,所以我们遍历数组查看是否有参数,有参数就进行替换。替换时需要注意的是遍历的是个数组,所以下标从0开始,在替换问号,替换的是第几个问号,没有第0个问号这一说吧。所以替换方法中第一个参数是i+1。

工具类

img

这里框中设成私有为了安全,静态为了类名能直接调用,但是别加final,用了final成自定义常量了,下面就用不了

img

img
img
img

终极版本

  在使用第四个版本之前需要使用到一个第三方的工具包:commons-dbutils-1.7.jar这个可以去官网下载。

工具类

img

接口
img

实现类
img
img

终极版的改变在于引入的第三方工具包的强大,这一次我们的util层特别的简单,不在定义变量而是直接传入。还新建了方法返回线程池,接下来重点在实现方法时,可以看到我反复在框一条代码。

QueryRunner queryRunner = new QueryRunner(DBCPUtil.getDataSource());

  重点就在这了,这个类是jar包中的类,这个jar包来自阿帕奇。这个类创建时需要传入一个数据库连接池对象。这里我们在DBCPUtil类中已经有返回连接池对象了,为什么要单独一个方法返回数据库连接池对象,因为定义时,数据库连接池是静态私有的,只有本类才能使用,所以用方法返回出去,使得dao层的实现类可以使用。创建的这个对象他是用来执行sql命令的,通过调用方法update这个方法完成一系列操作,比如分配Connection对象都是由这来执行的。

img

  update和query,在该包中,增删改所用的方法都是update,与查询有关的都用query方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jayden 

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值