第三个版本
第一个改变的地方就是在util中新定义了三个需要关闭的变量,这里框中设成私有为了安全,静态为了类名能直接调用,但是别加final,用了final成自定义常量了,下面就用不了刚开始置为空,在封装的close方法中只要不是null说明用过了就可以关闭。
第二个改变的是我们发现增删改的代码是差不多的可以封装成一个方法,差距就在于增删改根据条件的不同,问号的数量不同罢了。所以我们引入了可变参数可变参数也叫可变数组,所以我们遍历数组查看是否有参数,有参数就进行替换。替换时需要注意的是遍历的是个数组,所以下标从0开始,在替换问号,替换的是第几个问号,没有第0个问号这一说吧。所以替换方法中第一个参数是i+1。
工具类
这里框中设成私有为了安全,静态为了类名能直接调用,但是别加final,用了final成自定义常量了,下面就用不了
终极版本
在使用第四个版本之前需要使用到一个第三方的工具包:commons-dbutils-1.7.jar这个可以去官网下载。
工具类
接口
实现类
终极版的改变在于引入的第三方工具包的强大,这一次我们的util层特别的简单,不在定义变量而是直接传入。还新建了方法返回线程池,接下来重点在实现方法时,可以看到我反复在框一条代码。
QueryRunner queryRunner = new QueryRunner(DBCPUtil.getDataSource());
重点就在这了,这个类是jar包中的类,这个jar包来自阿帕奇。这个类创建时需要传入一个数据库连接池对象。这里我们在DBCPUtil类中已经有返回连接池对象了,为什么要单独一个方法返回数据库连接池对象,因为定义时,数据库连接池是静态私有的,只有本类才能使用,所以用方法返回出去,使得dao层的实现类可以使用。创建的这个对象他是用来执行sql命令的,通过调用方法update这个方法完成一系列操作,比如分配Connection对象都是由这来执行的。
update和query,在该包中,增删改所用的方法都是update,与查询有关的都用query方法。