JavaWeb之DButils(四)使用DBUtils实现增删查改
来源:互联网 发布:java图形界面插件 编辑:程序博客网 时间:2024/06/03 19:58
DBUtils是JDBC的简化开发工具包
一、JavaBean组件
JavaBean就是一个组件,在开发中常用于封装数据,有以下特性:
1.需要实现接口:java,io.Serializable(也可省略)
2.提供私有字段:private 类型 字段名;
3.提供get/set方法
4.提供无参构造
package com.shuhuadream.domain;public class Sort {private int sid;private String sname;private double sprice;private String sdesc;public Sort(int sid, String sname, double sprice, String sdesc) {super();this.sid = sid;this.sname = sname;this.sprice = sprice;this.sdesc = sdesc;}public Sort(){}public int getSid() {return sid;}public void setSid(int sid) {this.sid = sid;}public String getSname() {return sname;}public void setSname(String sname) {this.sname = sname;}public double getSprice() {return sprice;}public void setSprice(double sprice) {this.sprice = sprice;}public String getSdesc() {return sdesc;}public void setSdesc(String sdesc) {this.sdesc = sdesc;}@Overridepublic String toString() {return "Sort [sid=" + sid + ", sname=" + sname + ", sprice=" + sprice + ", sdesc=" + sdesc + "]";}}
二、DBUtils完成增删改查
1、概述
2、QueryRunner核心类
3、ResultSetHandle结果集处理类
4、DBUtils工具类
三、测试DBUtils工具类 增删改操作,使用到QueryRunner类
package com.shuhuadream.queryrunner;import java.sql.SQLException;import javax.sql.DataSource;import org.apache.commons.dbutils.QueryRunner;import org.junit.Test;import com.shuhuadream.jdbc.utils01.C3P0Utils;/*测试DBUtils工具类 增删改操作 * 使用QueryRunner类,实现对数据表的 * insert delete update * 调用QueryRunner类的方法 update (Connection con,String sql,Object...param) * Object...param 可变参数,Object类型,SQL语句会出现?占位符 * 数据库连接对象,自定义的工具类传递 */public class QueryRunnerDemo {private static DataSource dataSource = C3P0Utils.getDataSource();//定义方法,使用QueryRunner类的方法delete将数据表的数据删除 @Testpublic void delete(){try {//创建QueryRunner类对象QueryRunner qr = new QueryRunner(dataSource);//写删除的SQL语句String sql = "DELETE FROM sort WHERE sid=?";//调用QueryRunner方法updateint row = qr.update(sql, 27);if(row>0){System.out.println("删除成功!");}else{System.out.println("删除失败!");}} catch (SQLException e) {e.printStackTrace();}}//定义方法,使用QueryRunner类的方法update将数据表的数据修改@Test public void update(){try {//创建QueryRunner类对象QueryRunner qr = new QueryRunner(dataSource);//写修改数据的SQL语句String sql = "UPDATE sort SET sname=?,sprice=?,sdesc=? WHERE sid=?";//定义Object数组,存储?中的参数Object[] params = {"月饼",100.88,"中秋佳节月饼促销",25};//调用QueryRunner方法updateint row = qr.update(sql, params);if(row>0){System.out.println("修改成功!");}else{System.out.println("修改失败!");}} catch (SQLException e) {e.printStackTrace();}}/* * 定义方法,使用QueryRunner类的方法update向数据表中,添加数据 */@Testpublic void insert(){try {//创建QueryRunner类对象QueryRunner qr = new QueryRunner(dataSource);String sql = "INSERT INTO sort (sname,sprice,sdesc)VALUES(?,?,?)";//将三个?占位符的实际参数,写在数组中Object[] params = {"体育用品",289.32,"购买体育用品"};//调用QueryRunner类的方法update执行SQL语句int row = qr.update(sql, params);if(row>0){System.out.println("数据添加成功!");}else{System.out.println("数据添加失败!");}} catch (SQLException e) {e.printStackTrace();}}}
四、使用DBUtils运用QueryRunner数据进行查询操作并使用ResultSetHandle结果集处理类处理结果集
package com.shuhuadream.queryrunner;import java.sql.SQLException;import java.util.List;import java.util.Map;import javax.sql.DataSource;import org.apache.commons.dbutils.*;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 org.junit.Test;import com.shuhuadream.domain.Sort;import com.shuhuadream.jdbc.utils01.C3P0Utils;/** * QueryRunner数据查询操作 * 调用QueryRunner类方法query(Connection con,String sql,ResultSetHandler r,Object..params) * ResultSetHandler r 结果集的处理方式,传递ResultSetHandler接口实现类 * Object...params sql语句的?占位符 * * 注意:query方法返回值,返回的是T 泛型,具体返回值类型,跟随结果集处理方式变化 * */public class QueryRunnerDemo02 {private static DataSource dataSource = C3P0Utils.getDataSource();/** * 结果集第一种处理方法,ArrayHandler * 将结果第一行存储到对象数组中Object[] * @throws SQLException * */public void ArrayHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用query执行查询,传递连接对象,SQL语句,结果集处理方式的实现类 //返回对象数组Object[] result = qr.query(sql,new ArrayHandler());for (Object obj : result) {System.out.println(obj);}} catch (SQLException e) {e.printStackTrace();}}/** * 结果集的第二种处理方法,ArrayListHandler * 将结果集的每一行,封装到对象数组中,出现很多对象数组 * 对象数组存储到List集合 * @throws SQLException * */@Testpublic void arrayListHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用query方法,结果集处理的参数上,传递实现类ArrayListHandler//方法返回值 每行是一个数组List<Object[]> result = qr.query(sql, new ArrayListHandler());//集合的遍历for (Object[] objs : result) {for (Object obj : objs) {System.out.print(obj+"\t");}System.out.println();}} catch (SQLException e) {e.printStackTrace();}}/** * 结果集的第三种处理方法BeanHandler * 将结果集的第一行数据,封装为JavaBean对象 * 注意:被封装成数据到JavaBean对象,Sort类必须有空参构造 * @throws SQLException * */@Testpublic void beanHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用方法,传递结果集实现BeanHandler//BeanHandler(Class<T> type)Sort s = qr.query(sql,new BeanHandler<Sort>(Sort.class));System.out.println(s);} catch (SQLException e) {e.printStackTrace();}} /** * 结果集第四种处理方法,BeanListHandler * 将数据结果集的每一行数据,封装为JavaBean对象 * 多个JavaBean对象封装到List集合中 * @throws SQLException * */@Testpublic void beanListHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用方法传递结果集的实现类BeanListHandler//BeanListHandler(Class<T> type)List<Sort> list = qr.query(sql, new BeanListHandler<Sort>(Sort.class));for (Sort s : list) {System.out.println(s);}} catch (SQLException e) {e.printStackTrace();}}/** * 结果集第五种处理方法,ColumnListHandler * 结果集,指定列的数据,存储到List集合中 * List<Object> 每个列数据类型不同 * @throws SQLException * */@Testpublic void columnListHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用方法query,传递结果集实现类ColumnListHandler//实现类构造方法,使用字符串的列名List<Object> list = qr.query(sql, new ColumnListHandler("sname"));for (Object obj : list) {System.out.println(obj);}} catch (SQLException e) {e.printStackTrace();}}/** * 结果集第六种处理方法 ScalarHandler * 对于查询后,只有一个结果 * @throws SQLException * */@Testpublic void scalarHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT COUNT(*) FROM sort";//调用方法query,传递结果集处理类ScalarHandlerObject count = qr.query(sql,new ScalarHandler());System.out.println(count);} catch (SQLException e) {e.printStackTrace();}}/** * 结果集的第七种处理方式,MapHandler * 将结果集第一行数据,封装到Map集合中 * Map<键,值> 键:列名 值:这列数据 * @throws SQLException * */@Testpublic void mapHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用方法query,传递结果集实现类MapHandler//返回值:Map集合,Map接口实现类 泛型Map<String, Object> map = qr.query(sql,new MapHandler());for (String key : map.keySet()) {System.out.println(key+"..."+map.get(key));}} catch (SQLException e) {e.printStackTrace();}}/** * 结果集第八种处理方法,MapListHandler * 将结果集每一行存储到Map集合,键:列名 值:数据 * Map集合过多,存储到List集合 * @throws SQLException * */@Testpublic void mapListHandler(){try {QueryRunner qr = new QueryRunner(dataSource);String sql = "SELECT * FROM sort";//调用方法query,传递结果集实现类MapListHander//返回值List集合,存储的是Map集合List<Map<String, Object>> list = qr.query(sql,new MapListHandler());for (Map<String, Object> map : list) {for (String key : map.keySet()) {System.out.print(key+"..."+map.get(key));}System.out.println();}} catch (SQLException e) {e.printStackTrace();}}}
该操作用到了上一篇笔记当中的C3P0Utils工具类,实际开发当中建议使用C3P0Utils工具类
后记:每一天都是新的,学习路上加油
阅读全文
0 0
- JavaWeb之DButils(四)使用DBUtils实现增删查改
- 使用DbUtils实现增删改查
- DBUtils实现增删改查
- DButils的使用(增删改查)
- DbUtils增删改查
- DbUtils增删改查
- 使用Dbutils进行增删改查
- Dbutils数据库增删改查
- DBUtils学习之——使用ResultSetHandler接口的各个实现类实现数据库的增删改查
- 【笔记】c3p0+dbUtils+Ajax+Json实现【增删改查】Demo
- 使用DbUtils实现增删改查——ResultSetHandler 接口的实现类
- 使用DbUtils实现增删改查——ResultSetHandler接口的实现类
- 使用DbUtils实现增删改查——ResultSetHandler接口的实现类
- 【SQL】JDBC之运用dbutils组件实现对数据库的增删改查等操作
- 使用DBUtils第三方工具类,实现MySQL数据库的增删改查
- DBUtils创建数据库,增删改查
- mysql笔记九——Dbutils的使用(增删改查,事务)
- DBUtils实现增、删、改、查
- android studio 项目结构 汉化
- python
- CentOS6.7 linux系统下安装jdk
- HDU 3998 Sequence 最大流+最长上升子序列
- 基于php常用函数总结(数组,字符串,时间,文件操作)
- JavaWeb之DButils(四)使用DBUtils实现增删查改
- 功能: 窗体登出功能实现 (C#学习日记2017-09-06)
- 从前端传一个json格式数据到Spring MVC 控制台
- 今天第一次写博客,希望各位多多支持!!!!!!
- Qt学习之旅---3.文件处理,小例子文本编辑器
- 解析自定义属性
- 排序练习1
- 链表的插入、修改、删除、遍历--java
- limit