重新学javaweb ---- DbUtils
2016-05-07 11:06
369 查看
1.DbUtils
工具类
2.QueryRunner – 两行代码搞定增删改查
(1)QueryRunner() –需要控制事务时,使用这组方法
(2)QueryRunner(DataSource ds) –不需要控制事务用这组方法
在创建QueryRunner对象时,不传递数据源给它,是为了保证这些条SQL在同一个事务中进行,若传了数据源 可能他们会从
* 连接池里取不同的connection 没法进行事务控制 我们在逻辑层手动获取数据库连接,然后让这几条SQL使用同一个数据库连接执行
例子:
工具类
2.QueryRunner – 两行代码搞定增删改查
(1)QueryRunner() –需要控制事务时,使用这组方法
int update(Connection conn, String sql) Execute an SQL INSERT, UPDATE, or DELETE query without replacement parameters. int update(Connection conn, String sql, Object... params) Execute an SQL INSERT, UPDATE, or DELETE query. int update(Connection conn, String sql, Object param) Execute an SQL INSERT, UPDATE, or DELETE query with a single replacement parameter. <T> T query(Connection conn, String sql, ResultSetHandler<T> rsh) Execute an SQL SELECT query without any replacement parameters. T> T query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) Execute an SQL SELECT query with replacement parameters.
(2)QueryRunner(DataSource ds) –不需要控制事务用这组方法
在创建QueryRunner对象时,不传递数据源给它,是为了保证这些条SQL在同一个事务中进行,若传了数据源 可能他们会从
* 连接池里取不同的connection 没法进行事务控制 我们在逻辑层手动获取数据库连接,然后让这几条SQL使用同一个数据库连接执行
int update(String sql) Executes the given INSERT, UPDATE, or DELETE SQL statement without any replacement parameters. int update(String sql, Object... params) Executes the given INSERT, UPDATE, or DELETE SQL statement. int update(String sql, Object param) Executes the given INSERT, UPDATE, or DELETE SQL statement with a single replacement parameter. <T> T query(String sql, ResultSetHandler<T> rsh) Executes the given SELECT SQL without any replacement parameters. <T> T query(String sql, ResultSetHandler<T> rsh, Object... params) Executes the given SELECT SQL query and returns a result object.
3.ResultSetHandler 实现类
ArrayHandler:把结果集中的第一行数据转成对象数组。 ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。 !!!!BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。 !!!!BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。 MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。 MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List ColumnListHandler:将结果集中某一列的数据存放到List中。 KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List<Map>),再把这些map再存到一个map里,其key为指定的列。 !!!!!ScalarHandler:获取结果集中第一行数据指定列的值,常用来进行单值查询
例子:
public class RSHanlderDemo { //ScalarHandler:获取结果集中第一行数据指定列的值,常用来进行单值查询 @Test public void tes9() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Long count = (Long)runner.query("select count(*) from account",new ScalarHandler()); System.out.println(count); } //KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里(List<Map>),再把这些map再存到一个map里,其key为指定的列。 @Test //{1={id=1, name=a, money=999.0}, 4={id=4, name=c, money=1000.0}} public void tes8() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Map<Object, Map<String, Object>> map = runner.query("select * from account where money>?", new KeyedHandler("id"),500); System.out.println(map); } //ColumnListHandler:将结果集中某一列的数据存放到List中。 @Test //[999.0, 1000.0] public void tes7() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); List<Object>list = runner.query("select * from account where money>?", new ColumnListHandler(3),500); System.out.println(list); } //MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List @Test //[{id=1, name=a, money=999.0}, {id=4, name=c, money=1000.0}] public void tes6() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); List<Map<String, Object>> list = runner.query("select * from account where money>?", new MapListHandler(),500); System.out.println(list); } //MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。 @Test //{id=1, name=a, money=999.0} public void tes5() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Map<String, Object> map = runner.query("select * from account where money>?", new MapHandler(),1); System.out.println(map); } //BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。 @Test public void tes4() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); List<Account>list = runner.query("select * from account where money>?", new BeanListHandler<Account>(Account.class),20); System.out.println(list); } //BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。 @Test public void tes3() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Account acc = runner.query("select * from account where money>?", new BeanHandler<Account>(Account.class),500); System.out.println(acc); } //ArrayListHandler:把结果集中的每一行数据都转成一个对象数组,再存放到List中。 @Test public void tes2() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); List<Object[]> list = runner.query("select * from account where money>?", new ArrayListHandler(),500); System.out.println(list.get(0)[1]); //a System.out.println(list); } //ArrayHandler:把结果集中的第一行数据转成对象数组。 @Test public void test1() throws SQLException{ QueryRunner runner = new QueryRunner(new ComboPooledDataSource()); Object[] objs = runner.query("select * from account where money>?", new ArrayHandler(),500); System.out.println(objs); } }
相关文章推荐
- Apache Commons DbUtils工具包使用介绍
- DbUtils源码阅读一:初识项目
- DbUtils源码阅读二:DbUtils与QueryLoader
- ResultSetHandler接口的实现类
- plupload:在一个jsp中创建多个上传控件
- JDBC的轻量级封装DBUtils开源组件的使用(一)
- Java Web中web.xml文件的作用
- DbUtils工具简化JDBC开发
- Commons DbUtils
- DBUtil 代码细节
- Java Web项目表单数据存入数据库中文乱码解决
- 使用maven构建java/java web项目
- org.apache.commons.fileupload.FileUploadBase$SizeLimitExceededException:
- java 获取表单传递的值
- java web 接收发送json格式的数据
- MyEclipse中spring_servlet.xml报异常错误:Referenced file contains error(...)For&n
- JAVA WEB 导出 Excel表格
- JAVA WEB 导出 Word
- Tomcat安装、配置、优化及负载均衡详解
- web 中保存头像功能