天天看点

JavaWeb之DButils(四)使用DBUtils实现增删查改

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;
	}

	@Override
	public String toString() {
		return "Sort [sid=" + sid + ", sname=" + sname + ", sprice=" + sprice + ", sdesc=" + sdesc + "]";
	}
	
}

           

二、DBUtils完成增删改查

1、概述

JavaWeb之DButils(四)使用DBUtils实现增删查改

2、QueryRunner核心类

JavaWeb之DButils(四)使用DBUtils实现增删查改

3、ResultSetHandle结果集处理类

JavaWeb之DButils(四)使用DBUtils实现增删查改
JavaWeb之DButils(四)使用DBUtils实现增删查改

4、DBUtils工具类

JavaWeb之DButils(四)使用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将数据表的数据删除 
	@Test
	public void delete(){		
		try {
			//创建QueryRunner类对象
			QueryRunner qr = new QueryRunner(dataSource);	
			//写删除的SQL语句
			String sql = "DELETE FROM sort WHERE sid=?";
			//调用QueryRunner方法update
			int 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方法update
			int row = qr.update(sql, params);
			if(row>0){
				System.out.println("修改成功!");
			}else{
				System.out.println("修改失败!");
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
		
	}
	
	
	/*
	 * 定义方法,使用QueryRunner类的方法update向数据表中,添加数据
	 */
	@Test
	public 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 
	 * */
	@Test
	public 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 
	 * */
	@Test
	public 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 
	 * */
	@Test
	public 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 
	 * */
	@Test
	public 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 
	 * */
	@Test
	public void scalarHandler(){	
		try {
			QueryRunner qr = new QueryRunner(dataSource);
			String sql = "SELECT COUNT(*) FROM sort";
			//调用方法query,传递结果集处理类ScalarHandler
			Object count = qr.query(sql,new ScalarHandler());
			System.out.println(count);
		} catch (SQLException e) {
			e.printStackTrace();
		}
	
	}
	
	/**
	 * 结果集的第七种处理方式,MapHandler
	 * 将结果集第一行数据,封装到Map集合中
	 * Map<键,值> 键:列名 值:这列数据
	 * @throws SQLException 
	 * */
	@Test
	public 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 
	 * */
	@Test
	public 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工具类

后记:每一天都是新的,学习路上加油