首页 分享 JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作

JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作

来源:花匠小妙招 时间:2024-09-10 11:36

JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作

氨基钠IP属地: 浙江

2018.12.25 13:57:10字数 35阅读 523

一、使用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方法update int 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方法update int 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,传递结果集处理类ScalarHandler long 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(); } } }

更多精彩内容,就在简书APP

"小礼物走一走,来简书关注我"

还没有人赞赏,支持一下

总资产10共写了15.9W字获得253个赞共89个粉丝

序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...

沈念sama阅读 192,172评论 5赞 459

序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...

文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...

文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...

正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...

茶点故事阅读 60,563评论 4赞 352

文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...

那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...

文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...

序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...

正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...

茶点故事阅读 34,343评论 2赞 305

正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...

茶点故事阅读 36,117评论 1赞 322

序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...

正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...

茶点故事阅读 37,360评论 3赞 296

文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...

文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...

我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...

正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...

茶点故事阅读 40,432评论 2赞 335

推荐阅读更多精彩内容

本文主要内容1、DBUtils2、连接池 01DButils工具类的介绍个三个核心类 A: DButils工具类的...

前言 本文参考转发摘自:【郭霖博客】http://blog.csdn.net/guolin_blog?viewmo...

关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...

中v中阅读 31,858评论 2赞 89

邻居们都说你今年八十岁了,也有人说也许已经八十好几了。问你,你咧开装着假牙的嘴,摆摆手,自己都说不清楚。阳光斜斜地...

不得不说。女人是一个很傻的生物。 明明知道,他不会维护你,却还傻傻的一次又一次的寄希望于他 明明知道,他的情商负值...

相关知识

JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
【花店及花木管理软件】免费在线试用
花朵上的大青虫
知网查重参考文章没有查出来
python利用c4.5决策树对鸢尾花卉数据集进行分类(iris)
北京拟增种圆柏 市民担忧“易过敏”
北京拟增种圆柏 市民担忧“易过敏” 园林部门回应
遗传操作在植物育种上应用的局限及前景
教师节收到鲜花月饼后,老师删除了我的微信
高效液相色谱法同时分离测定仁用杏花芽中8种植物激素

网址: JavaWeb之DBUtils(一)QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作 https://www.huajiangbk.com/newsview104491.html

所属分类:花卉
上一篇: 光照强度影响花卉的花蕾开放,下面
下一篇: 政务资源目录体系(57页)

推荐分享