JavaWeb之DBUtils(一)QueryRunner类
2018-02-20 21:00
155 查看
DBUtils中的QueryRunner的使用: QueryRunner中提供了对SQL语句操作的api; 主要有三个方法: query():用于执行select(查询);
update():用于执行insert(插入)/update(更新)/delete(删除);
batch():批处理;
query(String sql, Object[] params, ResultSetHandler rsh):方法本身不提供数据库连接,执行选择查询,在查询中,对象阵列的值被用来作为查询的置换参数。
query(Connection conn, String sql, ResultSetHandler rsh):执行无需参数的选择查询。
update(Connection conn, String sql, Object[] params):被用来执行插入、更新或删除(DML)操作。
QueryRunner qr = new QueryRunner();
String sql = "INSERT INTO sort (sname,sprice,sdesc)VALUES(?,?,?)";
//将三个?占位符的实际参数,写在数组中
Object[] params = {"体育用品",289.32,"购买体育用品"};
//调用QueryRunner类的方法update执行SQL语句
int row = qr.update(con, sql, params);
System.out.println(row);
DbUtils.closeQuietly(con);update //创建QueryRunner类对象
QueryRunner qr = new QueryRunner();
//写修改数据的SQL语句
String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?";
//定义Object数组,存储?中的参数
Object[] params = {"花卉",100.88,"情人节玫瑰花",4};
//调用QueryRunner方法update
int row = qr.update(con, sql, params);
System.out.println(row);
DbUtils.closeQuietly(con); delete //创建QueryRunner类对象
QueryRunner qr = new QueryRunner();
//写删除的SQL语句
String sql = "DELETE FROM sort WHERE sid=?";
//调用QueryRunner方法update
int row = qr.update(con, sql, 8);
System.out.println(row);
/*
* 判断insert,update,delete执行是否成功
* 对返回值row判断
* if(row>0) 执行成功
*/
DbUtils.closeQuietly(con);
update():用于执行insert(插入)/update(更新)/delete(删除);
batch():批处理;
使用
query(Connection conn, String sql, Object[] params, ResultSetHandler rsh):执行选择查询,在查询中,对象阵列的值被用来作为查询的置换参数。query(String sql, Object[] params, ResultSetHandler rsh):方法本身不提供数据库连接,执行选择查询,在查询中,对象阵列的值被用来作为查询的置换参数。
query(Connection conn, String sql, ResultSetHandler rsh):执行无需参数的选择查询。
update(Connection conn, String sql, Object[] params):被用来执行插入、更新或删除(DML)操作。
update
insert //创建QueryRunner类对象QueryRunner qr = new QueryRunner();
String sql = "INSERT INTO sort (sname,sprice,sdesc)VALUES(?,?,?)";
//将三个?占位符的实际参数,写在数组中
Object[] params = {"体育用品",289.32,"购买体育用品"};
//调用QueryRunner类的方法update执行SQL语句
int row = qr.update(con, sql, params);
System.out.println(row);
DbUtils.closeQuietly(con);update //创建QueryRunner类对象
QueryRunner qr = new QueryRunner();
//写修改数据的SQL语句
String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?";
//定义Object数组,存储?中的参数
Object[] params = {"花卉",100.88,"情人节玫瑰花",4};
//调用QueryRunner方法update
int row = qr.update(con, sql, params);
System.out.println(row);
DbUtils.closeQuietly(con); delete //创建QueryRunner类对象
QueryRunner qr = new QueryRunner();
//写删除的SQL语句
String sql = "DELETE FROM sort WHERE sid=?";
//调用QueryRunner方法update
int row = qr.update(con, sql, 8);
System.out.println(row);
/*
* 判断insert,update,delete执行是否成功
* 对返回值row判断
* if(row>0) 执行成功
*/
DbUtils.closeQuietly(con);
query(8种)
/** * QueryRunner数据查询操作 * 调用QueryRunner类方法query(Connection con,String sql,ResultSetHandler r,Object..params) * ResultSetHandler r 结果集的处理方式,传递ResultSetHandler接口实现类 * Object...params sql语句的?占位符 * * 注意:query方法返回值,返回的是T 泛型,具体返回值类型,跟随结果集处理方式变化 * */ /** * 结果集第一种处理方法,ArrayHandler * 将结果第一行存储到对象数组中Object[] * @throws SQLException * */ public static void ArrayHandler() throws SQLException { QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用query执行查询,传递连接对象,SQL语句,结果集处理方式的实现类 //返回对象数组 Object[] result = qr.query(con, sql,new ArrayHandler()); for (Object obj : result) { System.out.println(obj); } } /** * 结果集的第二种处理方法,ArrayListHandler * 将结果集的每一行,封装到对象数组中,出现很多对象数组 * 对象数组存储到List集合 * @throws SQLException * */ public static void arrayListHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用query方法,结果集处理的参数上,传递实现类ArrayListHandler //方法返回值 每行是一个数组 List<Object[]> result = qr.query(con, sql, new ArrayListHandler()); //集合的遍历 for (Object[] objs : result) { for (Object obj : objs) { System.out.print(obj+"\t"); } System.out.println(); } } /** * 结果集的第三种处理方法BeanHandler * 将结果集的第一行数据,封装为JavaBean对象 * 注意:被封装成数据到JavaBean对象,Sort类必须有空参构造 * @throws SQLException * */ public static void beanHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用方法,传递结果集实现BeanHandler //BeanHandler(Class<T> type) Sort s = qr.query(con, sql,new BeanHandler<Sort>(Sort.class)); System.out.println(s); } /** * 结果集第四种处理方法,BeanListHandler * 将数据结果集的每一行数据,封装为JavaBean对象 * 多个JavaBean对象封装到List集合中 * @throws SQLException * */ public static void beanListHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用方法传递结果集的实现类BeanListHandler //BeanListHandler(Class<T> type) List<Sort> list = qr.query(con, sql, new BeanListHandler<Sort>(Sort.class)); for (Sort s : list) { System.out.println(s); } } /** * 结果集第五种处理方法,ColumnListHandler * 结果集,指定列的数据,存储到List集合中 * List<Object> 每个列数据类型不同 * @throws SQLException * */ public static void columnListHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用方法query,传递结果集实现类ColumnListHandler //实现类构造方法,使用字符串的列名 List<Object> list = qr.query(con, sql, new ColumnListHandler<Object>("sname")); for (Object obj : list) { System.out.println(obj); } } /** * 结果集第六种处理方法、 * 对于查询后,只有一个结果 * @throws SQLException * */ public static void scalarHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT COUNT(*) FROM sort"; //调用方法query,传递结果集处理类ScalarHandler long count = qr.query(con,sql,new ScalarHandler<Long>()); System.out.println(count); } /** * 结果集的第七种处理方式,MapHandler * 将结果集第一行数据,封装到Map集合中 * Map<键,值> 4000 键:列名 值:这列数据 * @throws SQLException * */ public static void mapHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用方法query,传递结果集实现类MapHandler //返回值:Map集合,Map接口实现类 泛型 Map<String,Object> map = qr.query(con, sql,new MapHandler()); for (String key : map.keySet()) { System.out.println(key+"..."+map.get(key)); } } /** * 结果集第八种处理方法,MapListHandler * 将结果集每一行存储到Map集合,键:列名 值:数据 * Map集合过多,存储到List集合 * @throws SQLException * */ public static void mapListHandler() throws SQLException{ QueryRunner qr = new QueryRunner(); String sql = "SELECT * FROM sort"; //调用方法query,传递结果集实现类MapListHander //返回值List集合,存储的是Map集合 List<Map<String, Object>> list = qr.query(con, sql,new MapListHandler()); for (Map<String, Object> map : list) { for (String key : map.keySet()) { System.out.print(key+"..."+map.get(key)); } System.out.println(); } } }
相关文章推荐
- JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
- JavaWeb—DBUtils框架简介、DbUtils类、QueryRunner类 、ResultSetHandler接口
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.
- 重新学javaweb ---- DbUtils
- JavaWeb之DButils(三)使用C3P0实现数据库的连接池
- JavaWeb之DBUtils
- JavaWeb之DButils(四)使用DBUtils实现增删查改
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.
- JavaWeb基础—dbutils的简单入门
- [JavaWeb]DBUtils中的QueryRunner
- JavaWeb 后端 <十一> 之 DBUtils 框架 (基本使用 结果集 事务处理 对表读取)
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.
- Java web----DBUtils
- JAVAWEB开发之Tomcat内置连接池的配置和使用、DbUtils的使用详解和案例、以及元数据详解
- java--javaWeb--终极版JDBCUtils,使用事务、commons-dbutils、c3p0
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.
- javaweb-DBUtils
- JavaWeb之DButils(二)使用DBCP实现数据库的连接池
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.
- [JavaWeb]关于DBUtils中QueryRunner的一些解读.