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

一、使用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 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 type)
		Sort s = qr.query(con, sql,new BeanHandler(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 type)
		List list = qr.query(con, sql, new BeanListHandler(Sort.class));
		for (Sort s : list) {
			System.out.println(s);
		}
	}
	
	/**
	 * 结果集第五种处理方法,ColumnListHandler
	 * 结果集,指定列的数据,存储到List集合中
	 * List 每个列数据类型不同
	 * @throws SQLException 
	 * */
	public static void columnListHandler() throws SQLException{
		QueryRunner qr = new QueryRunner();
		String sql = "SELECT * FROM sort";
		//调用方法query,传递结果集实现类ColumnListHandler
		//实现类构造方法,使用字符串的列名
		List list = qr.query(con, sql, new ColumnListHandler("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());
		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 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> list = qr.query(con, sql,new MapListHandler());
		for (Map map : list) {
			for (String key : map.keySet()) {
				System.out.print(key+"..."+map.get(key));
			}
			System.out.println();
		}
	}
}
 
  

你可能感兴趣的:(Java)