DbUtils框架

DbUtils框架。简化代码操作。

QueryRunner 类

    构造器

    此类可实现数据库更新,查询等操作

    1 数据库的更新

    调用QueryRunner下的 update方法可实现数据库的更新操作。

    

/**
	 * 测试QueryRunner
	 * 1.创建QueryRunner对象
	 * 调用QueryRunner下的update方法,此方法可用于增删改。 
	 */
	public void testQueryRunnerUpdate(){
		//1.创建QueryRunner实现类
		QueryRunner queryRunner=new QueryRunner();
		String sql="update user set pwd = ?";
		Connection connection=null;
		
		try {
			connection=JdbcUtil.getConnection();
			System.out.println(connection);
			queryRunner.update(connection, sql, "56");
		} catch (Exception e) {
			// TODO: handle exception
		}finally {
			JdbcUtil.release(connection, null);
		}
	}

    2.数据库的查询操作。

    调用 query(Connection con , String sql ,ResultSetHandler <T> rsh ,Object ... args)

    源码:

public interface ResultSetHandler<T> {

    /**
     * Turn the <code>ResultSet</code> into an Object.
     * 
     * @param rs The <code>ResultSet</code> to handle.  It has not been touched
     * before being passed to this method.
     * 
     * @return An Object initialized with <code>ResultSet</code> data. It is
     * legal for implementations to return <code>null</code> if the 
     * <code>ResultSet</code> contained 0 rows.
     * 
     * @throws SQLException if a database access error occurs
     */
    public T handle(ResultSet rs) throws SQLException;

}

 1   在查询的返回的时候 如果用类实现了ResultSetHandler接口的话,则query的返回值就是handle方法的返回值。

    这是因为query内部,调用了ResultSetHandler下的handle 方法

 2. BeanHandler

    

	/**
	 *  3. BeanHandler: 把结果集的第一条记录转为创建BeanHandler对象时 传入的 Class运行实类对象
	 * BeanHandler(Class<T> type) 
	 */
	public void testBeanHandler() {
		Connection connection=null;
		QueryRunner queryRunner=null;
		String sql="select uname name,password from user where uname=?;";
		try {
			connection=JdbcUtil.getConnection();
			queryRunner=new QueryRunner();
			User user=queryRunner.query(connection, sql, new BeanHandler<>(User.class),"lw");
			System.out.println(user);
		}catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
		}finally {
			JdbcUtil.release(connection, null);
		}
	}

  3.BeanListHandler

/**
			 * BeanListHandler:把结果转换成一个list该list 不为 null,但是可能为空集合,(size=0)
			 * 若sql语句查询不到记录的话,list就为空集合,否则的话就将查询到的没一行创建 为  创建BeanListHandler是传入的
			 * 大的Class对象 的对象。
			 */
			
			public void testBeanListHandler() {
				Connection connection=null;
				QueryRunner queryRunner=null;
				String sql="select uname name,password from user;";
				try {
					connection=JdbcUtil.getConnection();
					queryRunner=new QueryRunner();
					List<User> list=queryRunner.query(connection, sql,new BeanListHandler<>(User.class));
					System.out.println(list);
				}catch (Exception e) {
					// TODO: handle exception
					e.printStackTrace();
				}finally {
					JdbcUtil.release(connection, null);
				}
			}

4.MapHandler

/**
	 *  4. MapHandler: 把结果集转为一个 Map 对象, 并返回. 若结果集中有多条记录, 仅返回
	 * 第一条记录对应的 Map 对象. Map 的键: 列名(而非列的别名), 值: 列的值
	 */
	public void testMapHandler() {
		Connection connection=null;
		QueryRunner queryRunner=null;
		try{
			String sql="select uname name , password from user";
			connection=JdbcUtil.getConnection();
			queryRunner=new QueryRunner();
			Map<String, Object> map= queryRunner.query(connection, sql, new MapHandler());
			System.out.println(map);
		}catch (Exception e) {
			// TODO: handle exception
		}finally {
			JdbcUtil.release(connection, null);
		}
	}
			/**
			 * BeanListHandler:把结果转换成一个list该list 不为 null,但是可能为空集合,(size=0)
			 * 若sql语句查询不到记录的话,list就为空集合,否则的话就将查询到的没一行创建 为  创建BeanListHandler是传入的
			 * 大的Class对象 的对象。
			 */
			
			public void testBeanListHandler() {
				Connection connection=null;
				QueryRunner queryRunner=null;
				String sql="select uname name,password from user;";
				try {
					connection=JdbcUtil.getConnection();
					queryRunner=new QueryRunner();
					List<User> list=queryRunner.query(connection, sql,new BeanListHandler<>(User.class));
					System.out.println(list);
				}catch (Exception e) {
					// TODO: handle exception
					e.printStackTrace();
				}finally {
					JdbcUtil.release(connection, null);
				}
			}

5.MapListHandler

	/**
	 *  MapListHandler: 把结果集转为一个 Map 对象的集合, 并返回. 
	 * Map 的键: 列名(而非列的别名), 值: 列的值
	 */
	public void testMapListHandler() {
		Connection connection=null;
		QueryRunner queryRunner=null;
		try{
			String sql="select uname name , password from user";
			connection=JdbcUtil.getConnection();
			queryRunner=new QueryRunner();
			List<Map<String, Object>> listMap= queryRunner.query(connection, sql, new MapListHandler());
			System.out.println(listMap);
		}catch (Exception e) {
			// TODO: handle exception
		}finally {
			JdbcUtil.release(connection, null);
		}
	}

6.ScalarHandler 返回一条记录。比如一个人的名字,一个人的身份证

@Test
	public void TestScalarHandler() {
		Connection connection=null;
		QueryRunner queryRunner=null;
		try{
			String sql="select uname name , password from user where uname = ?";
			connection=JdbcUtil.getConnection();
			queryRunner=new QueryRunner();
			Object object= queryRunner.query(connection, sql, new ScalarHandler(),"l");
			System.out.println(object);
		}catch (Exception e) {
			// TODO: handle exception
		}finally {
			JdbcUtil.release(connection, null);
		}
	}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值