ResultSetHandler 和 QueryRunner
ResultSetHandler是用来简化查询到的数据处理的.ResultSetHandler的实现方法可以不用创建实例对象去封装就能打印出来
查询到的全部数据.通过:

ArrayHandler:把结果集中的第一行数据转成对象数组。
ArrayListHandler:把结果集中的每一行数据都转成一个数组,再存放到List中。
BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。
BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。
ColumnListHandler:将结果集中某一列的数据存放到List中。
KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里,再把这些map再存到一个map里,其key为指定的key。
MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。
MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List

这些方法.


QueryRunner是用来简化增删改查的.
QueryRunner通过封装update()和query()方法使我们不用那么麻烦的每次都写那些update()和query()方法
而且可以帮我们自动关闭线程.但是,如果我们需要自己定义一个connection的话我们就需要自动的关闭connection
而且还需要最后记得commit一下.
比如我们需要涉及一个同步的事务的时候我们就需要自己定义一个connection.此时我们在调用update()和query()方法的时候需要把connection传进去.