DBUtils&事务

第一章 DBUtils

如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils。

DBUtils就是JDBC的简化开发工具包。需要项目导入commons-dbutils-1.6.jar才能够正常使用DBUtils工具。

1.1 概述

DBUtils是java编程中的数据库操作实用工具,小巧简单实用。DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码。

Dbutils三个核心功能介绍

  • QueryRunner中提供对sql语句操作的API.

  • ResultSetHandler接口,用于定义select操作后,怎样封装结果集.

  • DbUtils类,它就是一个工具类,定义了关闭资源与事务处理的方法

1.2 准备数据

  • 创建表:
-- 创建商品表
create table product(
    -- 商品主键
	pid int primary key,
    -- 商品名称
	pname varchar(20),
    -- 商品价格
	price double,
    -- 商品分类
	category_id varchar(32)
);
  • 插入表记录
INSERT INTO product(pid,pname,price,category_id) VALUES(1,'联想',5000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(2,'海尔',3000,'c001');
INSERT INTO product(pid,pname,price,category_id) VALUES(3,'雷神',5000,'c001');

INSERT INTO product(pid,pname,price,category_id) VALUES(4,'JACK JONES',800,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(5,'真维斯',200,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(6,'花花公子',440,'c002');
INSERT INTO product(pid,pname,price,category_id) VALUES(7,'劲霸',2000,'c002');

INSERT INTO product(pid,pname,price,category_id) VALUES(8,'香奈儿',800,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(9,'相宜本草',200,'c003');
INSERT INTO product(pid,pname,price,category_id) VALUES(10,'面霸',5,'c003');

INSERT INTO product(pid,pname,price,category_id) VALUES(11,'好想你枣',56,'c004');
INSERT INTO product(pid,pname,price,category_id) VALUES(12,'香飘飘奶茶',1,'c005');

INSERT INTO product(pid,pname,price,category_id) VALUES(13,'果9',1,NULL);

1.3 QueryRunner核心类介绍

1.3.1 提供数据源

  • 构造方法

    • QueryRunner(DataSource) 创建核心类,并提供数据源,内部自己维护Connection
  • 普通方法

    • update(String sql , Object ... params) 执行DML语句
    • query(String sql , ResultSetHandler , Object ... params) 执行DQL语句,并将查询结果封装到对象中。

1.3.2 提供连接

  • 构造方法
    • QueryRunner() 创建核心类,没有提供数据源,在进行具体操作时,需要手动提供Connection
  • 普通方法
    • update(Connection conn , String sql , Object ... params) 使用提供的Connection,完成DML语句
    • query(Connection conn , String sql , ResultSetHandler , Object ... params) 使用提供的Connection,执行DQL语句,并将查询结果封装到对象中。

1.4 QueryRunner实现添加、更新、删除操作

  • update(String sql, Object... params) 用来完成表数据的增加、删除、更新操作

1.4.1 添加

public void insert() throws SQLException{
   
	//获取一个用来执行SQL语句的对象   QueryRunner
	QueryRunner qr = new QueryRunner(C3P0Utils.getDataSource());
		
	String sql = " INSERT INTO product(pid,pname,price,category_id) VALUES(?,?,?,?);";
	Object[] params = {
   100,"百岁山", 5500, "c005"};
	int line = qr.update(sql,params);// 用来完成表数据的增加、删除、更新操作
	//结果集处理
	System.out.println("line = " + line);
}

1.4.2 更新

@Test
public void update() throws SQLException{
   
	//1 核心类
	QueryRunner queryRunner = new QueryRunner(C3P0Utils.getDataSource());
	//2 准备sql语句
	String sql = "update product set pname=?,price=?,category_id=? where pid=?";
	
	//3 准备实际参数
	Object[] params = {
   "芒果99","998","c009",13};
	
	//4 执行
	int r = queryRunner.update(sql, params);
	System.out.println(r);
	
}

1.4.3 删除

@Test
public void delete() throws SQLException{
   
	
	QueryRunner queryRunner = new QueryRunner(C3P0Utils.getDataSource());
	String sql = "delete from product where pid = ?";
	Object[] params = {
   99};
	int r = queryRunner.update(sql, params);
	System.out.println
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值