JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
来源:互联网 发布:java 动态代理模式 编辑:程序博客网 时间:2024/06/07 12:30
一、使用QueryRunner类,实现对数据表的 insert delete update
package com.shuhuadream.queryrunner;import java.sql.Connection;import java.sql.SQLException;import org.apache.commons.dbutils.DbUtils;import org.apache.commons.dbutils.QueryRunner;import com.shuhuadream.jdbcutil.JDBCUtilConfig;/* * 使用QueryRunner类,实现对数据表的 * insert delete update * 调用QueryRunner类的方法 update (Connection con,String sql,Object...param) * Object...param 可变参数,Object类型,SQL语句会出现?占位符 * 数据库连接对象,自定义的工具类传递 */public class QueryRunnerDemo {private static Connection con = JDBCUtilConfig.getConnection();public static void main(String[] args)throws SQLException {//insert();update();//delete();}/* * 定义方法,使用QueryRunner类的方法delete将数据表的数据删除 */public static void delete()throws SQLException{//创建QueryRunner类对象QueryRunner qr = new QueryRunner();//写删除的SQL语句String sql = "DELETE FROM sort WHERE sid=?";//调用QueryRunner方法updateint row = qr.update(con, sql, 8);System.out.println(row);/* * 判断insert,update,delete执行是否成功 * 对返回值row判断 * if(row>0) 执行成功 */DbUtils.closeQuietly(con);}/* * 定义方法,使用QueryRunner类的方法update将数据表的数据修改 */public static void update()throws SQLException{//创建QueryRunner类对象QueryRunner qr = new QueryRunner();//写修改数据的SQL语句String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?";//定义Object数组,存储?中的参数Object[] params = {"花卉",100.88,"情人节玫瑰花",4};//调用QueryRunner方法updateint row = qr.update(con, sql, params);System.out.println(row);DbUtils.closeQuietly(con);}/* * 定义方法,使用QueryRunner类的方法update向数据表中,添加数据 */public static void insert()throws SQLException{//创建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);}}
二、QueryRunner数据查询操作,结果集八种处理方法
package com.shuhuadream.queryrunner;import java.sql.Connection;import java.sql.SQLException;import java.util.List;import java.util.Map;import org.apache.commons.dbutils.QueryRunner;import org.apache.commons.dbutils.handlers.ArrayHandler;import org.apache.commons.dbutils.handlers.ArrayListHandler;import org.apache.commons.dbutils.handlers.BeanHandler;import org.apache.commons.dbutils.handlers.BeanListHandler;import org.apache.commons.dbutils.handlers.ColumnListHandler;import org.apache.commons.dbutils.handlers.MapHandler;import org.apache.commons.dbutils.handlers.MapListHandler;import org.apache.commons.dbutils.handlers.ScalarHandler;import com.shuhuadream.domain.Sort;import com.shuhuadream.jdbcutil.JDBCUtilConfig;/** * QueryRunner数据查询操作 * 调用QueryRunner类方法query(Connection con,String sql,ResultSetHandler r,Object..params) * ResultSetHandler r 结果集的处理方式,传递ResultSetHandler接口实现类 * Object...params sql语句的?占位符 * * 注意:query方法返回值,返回的是T 泛型,具体返回值类型,跟随结果集处理方式变化 * */public class QueryRunnerDemo02 {private static Connection con = JDBCUtilConfig.getConnection();public static void main(String[] args) throws SQLException {//ArrayHandler();//arrayListHandler();//beanHandler();//beanListHandler();//columnListHandler();//scalarHandler();//mapHandler();mapListHandler();}/** * 结果集第一种处理方法,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,传递结果集处理类ScalarHandlerlong count = qr.query(con,sql,new ScalarHandler<Long>());System.out.println(count);}/** * 结果集的第七种处理方式,MapHandler * 将结果集第一行数据,封装到Map集合中 * Map<键,值> 键:列名 值:这列数据 * @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();}}}
阅读全文
0 0
- JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
- JavaWeb之DButils(四)使用DBUtils实现增删查改
- MySQL数据表的CRUD(増、删、改、查)操作
- QueryRunner(DbUtils) 结果集实例
- 【SQL】JDBC之运用dbutils组件实现对数据库的增删改查等操作
- Java数据库的操作——DBUtils工具类结果集处理的方式有几种?
- DButils的使用(增删改查)
- DBUtils 查询操作的九种结果集处理
- 使用MyBatis进行对数据表的增删改查操作
- [JavaWeb]DBUtils中的QueryRunner
- c#中对cookie的几种操作(增、删、改、查)
- QueryRunner 核心运行类;在一般情况下如果执行CRUD的操作; 使用核心类QueryRunner 对数据库进行 增删改
- 数据表数据的增,删,改 ,查
- MySQL---操作数据表基本操作(增删改查)
- 用Oracle的增、删、改、查实现对DVD的操作(迷你DVD)
- 操作数据表中的记录(增删改查)
- Mybatis(一)—实现对数据库的增删改查操作
- DBUtils实现增、删、改、查
- codefores 538-C. Tourist's Notes(数学)
- spring mvc文件上传
- wdcp后台访问安全设置即限制域名/IP访问设置及清除方法
- Cocos2d-场景切换-CCTransitionFlipX和CCTransitionFade和CCTransitionSlideInL
- 关于z-index层级问题
- JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
- 动态链接时出现undefined symbol错误
- 经常出门的男人赶紧收藏起来,太实用了
- 记录一下
- VS2010程序打包操作(超详细的)
- log4j配置打印mybatis sql语句
- 文章标题
- 资料丨一套python学习视频,学完python基本可出师!
- winform运行后台运行cmd并实时输出运行信息