TxQueryRunner的介绍和用法

 TxQueryRunner类是common-dbutils下QueryRunner类的子类,用来简化JDBC操作。

TxQueryRunner类内部使用了JdbcUtils.getConnection()类来获取连接对象,以及使用JdbcUtils.releaseConnection()关闭连接。

主要用法有:

  1. int[] batch(String sql, Object[][] params):执行批处理,参数sql是SQL语句模板,params为参数;
  2. T query(String sql, ResultSetHandler<T> rh):执行查询,执行查询,参数sql为要执行的查询语句模板,rh是结果集处理,用来把结果集映射成你想要的结果;
  3. T query(String sql, ResultSetHandler<T> rh, Object… params):执行查询,参数sql为要执行的查询语句模板,rh是结果集处理,用来把结果集映射成你想要的结果,params是sql语句的参数;
  4. int update(String sql):执行增、删、改语句,参数sql是要执行的SQL语句;
  5. int update(Stringsql, Object param):执行增、删、改语句,参数sql是要执行的SQL语句,参数param是参数(一个参数);
  6. int update(String sql, Object… params):执行增、删、改语句,参数sql是要执行的SQL语句,参数params是参数(多个参数);

具体使用方法:

1.导入相应的JARs

mysql驱动jar包:mysql-connector-java-5.1.28-bin.jar

C3P0需要的jar包:c3p0-0.9.2-pre1.jar和mchange-commons-0.2.jar

2.在src下添加C3P0配置文件:c3p0-config.xml

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
	<default-config> 
		<property name="jdbcUrl">jdbc:mysql://localhost:3306/grain</property>
		<property name="driverClass">com.mysql.jdbc.Driver</property>
		<property name="user">root</property>
		<property name="password">123456</property>
		
		<property name="acquireIncrement">3</property>
		<property name="initialPoolSize">10</property>
		<property name="minPoolSize">2</property>
		<property name="maxPoolSize">10</property>
	</default-config>
</c3p0-config>

测试TxQueryRunner

package cn.itcast.test;

import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
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 cn.itcast.commons.CommonUtils;
import cn.itcast.jdbc.JdbcUtils;
import cn.itcast.jdbc.TxQueryRunner;

/**
 * TxQueryRunner它是QueryRunner的子类!(commons-dbutils.jar)
 *   可用起来与QueryRunner相似的!
 *   我们的类支持事务!它底层使用了JdbcUtils来获取连接!
 *   
 * 简化jdbc的操作
 * QueryRunner的三个方法:
 * * update() --> insert、update、delete
 * * query() --> select
 * * batch() --> 批处理
 * @author qdmmy6
 *
 */
public class TxQueryRunnerTest {
	/**
	 * 测试update()方法,用来执行insert、update、delete语句
	 * @throws SQLException
	 */
	@Test
	public void testUpdate() throws SQLException {
		String sql = "insert into t_person(pid,pname,age,sex) values(?,?,?,?)";
		Object[] params = {"1", "p1", 1, "男"};//给sql中对应的参数
		
		QueryRunner qr = new TxQueryRunner();//我们没有给对象提供连接池
		qr.update(sql, params);//执行sql,也不提供连接,它内部会使用JdbcUtils来获取连接
	}
	
	/**
	 * 使用事务
	 * @throws SQLException
	 */
	@Test
	public void testUpdate2() throws Exception {
		try {
			JdbcUtils.beginTransaction();//开启事务
			
			String sql = "insert into t_person(pid,pname,age,sex) values(?,?,?,?)";
			QueryRunner qr = new TxQueryRunner();
			Object[] params = {"2", "p2", 2, "女"};
			qr.update(sql, params);//执行
			
			if(false) {
				throw new Exception();
			}
			
			params = new Object[]{"3", "p3", 3, "女"};
			qr.update(sql, params);//执行			
			
			JdbcUtils.commitTransaction();//提交事务
		} catch(Exception e) {
			try {
				JdbcUtils.rollbackTransaction();//回滚事务
			} catch (SQLException e1) {
			}
			throw e;
		}		
	}
	
	/**
	 * 测试查询方法
	 *   我们知道JDBC查询的结果的是ResultSet
	 *   而QueryRunner查询的结果是通过ResultSet映射后的数据。
	 *     * QueryRunner第一步是执行select,得到ResultSet
	 *     * 把ResultSet转换成其他类型的!
	 *   通过转换结果:
	 *      * javaBean:把结果集封装到javaBean中
	 *      * Map:把结果集封装到Map中
	 *      * 把结果集封装到Object中(结果集是单行单列)
	 * @throws SQLException 
	 *      
	 *  
	 */
	/*
	 * 单行结果集映射到javaBean中
	 */
	@Test
	public void testQuery1() throws SQLException {
		String sql = "select * from t_person where pid=?";
		QueryRunner qr = new TxQueryRunner();
		/*
		 * 第二个参数类型为ResultSetHandler,它是一个接口,表示映射的结果类型。
		 * 
		 * BeanHandler --> 它是ResultSetHandler的实现类,它的作用是把结果集封装到Person对象中
		 */
		Person p = qr.query(sql, new BeanHandler<Person>(Person.class), "1");
		System.out.println(p);
	}
	
	/**
	 * 使用BeanListHandler
	 *   把多行结果集映射到List<Bean>,即多个JavaBean对象。
	 *   一行结果集记录对应一个javaBean对象,多行就对应List<Bean>
	 * @throws SQLException
	 */
	@Test
	public void testQuery2() throws SQLException {
		String sql = "select * from t_person";
		QueryRunner qr = new TxQueryRunner();
		/*
		 * 第二个参数类型为ResultSetHandler,它是一个接口,表示映射的结果类型。
		 * 
		 * BeanListHandler --> 它是ResultSetHandler的实现类,
		 *   它的作用是把结果集封装到List<Person>对象中
		 */
		List<Person> list = qr.query(sql, new BeanListHandler<Person>(Person.class));
		System.out.println(list);
	}
	
	/**
	 * 使用MapHandler,把单行结果集封装到Map对象中
	 * @throws SQLException
	 */
	@Test
	public void testQuery3() throws SQLException {
		String sql = "select * from t_person where pid=?";
		QueryRunner qr = new TxQueryRunner();
		/*
		 * 第二个参数类型为ResultSetHandler,它是一个接口,表示映射的结果类型。
		 * 
		 * BeanListHandler --> 它是ResultSetHandler的实现类,
		 *   它的作用是把结果集封装到List<Person>对象中
		 */
		Map<String, Object> map = qr.query(sql, new MapHandler(), "1");
		System.out.println(map);
	}
	
	/**
	 * 使用MapListHandler,把多行结果集封装到List<Map>中,即多个Map
	 *   一行对应一个Map,多行对应List<Map>
	 * @throws SQLException
	 */
	@Test
	public void testQuery4() throws SQLException {
		String sql = "select * from t_person";
		QueryRunner qr = new TxQueryRunner();
		/*
		 * 第二个参数类型为ResultSetHandler,它是一个接口,表示映射的结果类型。
		 * 
		 * BeanListHandler --> 它是ResultSetHandler的实现类,
		 *   它的作用是把结果集封装到List<Person>对象中
		 */
		List<Map<String, Object>> mapList = qr.query(sql, new MapListHandler());
		System.out.println(mapList);
	}
	
	/**
	 * 使用ScalarHandler,把单行单列的结果集封装到Object中
	 * @throws SQLException
	 */
	@Test
	public void testQuery5() throws SQLException {
		String sql = "select count(*) from t_person";//结果集是单行单列的
		QueryRunner qr = new TxQueryRunner();

		Object obj = qr.query(sql, new ScalarHandler());
		/*
		 * 我们知道select count(1),结果一定是个整数!
		 * > Integer
		 * > Long
		 * > BigInteger
		 * 
		 * 不同的驱动,结果不同!
		 * 无论是哪种类型,它都是Number类型!强转成Number一定不出错
		 */
		Number number = (Number)obj;
		long cnt = number.longValue();
		System.out.println(cnt);
	}
	
	/**
	 * 一行结果集中包含了两张表的列
	 * 使用MapHandler来处理
	 * 1. 把结果集封装到map中
	 * 2. 使用map生成Person对象
	 * 3. 使用map生成address对象
	 * 4. 把两个实体对象建立关系
	 * @throws SQLException
	 */
	@Test
	public void testQuery6() throws SQLException {
		String sql = "SELECT * FROM t_person p, t_address a WHERE p.aid=a.aid AND p.pid=?";
		QueryRunner qr = new TxQueryRunner();
		/*
		 * 1. 得到Map
		 */
		Map map = qr.query(sql, new MapHandler(), "aaa");
		/*
		 * 2. 把Map中部分数据封装到Person中
		 */
		Person p = CommonUtils.toBean(map, Person.class);
		/*
		 * 3. 把Map中部分数据封装到Address中
		 */
		Address addr = CommonUtils.toBean(map, Address.class);
		/*
		 * 4. 建立两个实体的关系
		 */
		p.setAddress(addr);
		
		System.out.println(p);
	}
}

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值