DBUtils&事务

本文详细介绍了DBUtils工具的使用,包括QueryRunner的核心类和事务处理,以及MySQL和JDBC的事务操作。通过实例展示了如何使用DBUtils进行数据的增删改查,并探讨了事务的ACID特性、并发访问问题和不同隔离级别的解决方案。
摘要由CSDN通过智能技术生成

#DBUtils&事务

  • 掌握DBUtils实现增删改
  • 掌握DBUtils实现查询
  • 理解事务的概念
  • 理解脏读,不可重复读,幻读的概念及解决办法
  • 能够在MySQL中使用事务
  • 能够在JDBC中使用事务
  • 能够在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 = {
   
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThreadLocal是一个线程内部的数据存储类,它可以在多线程环境下为每个线程保存一个独立的变量副本,从而保证了线程安全。DBUtils是一个Java数据库工具库,提供了简化JDBC编程的API,可以快速地完成对数据库的操作。 在使用DBUtils处理事务时,我们可以结合ThreadLocal来实现线程安全的事务处理。具体的实现步骤如下: 1. 定义一个ThreadLocal变量,用于存储Connection对象。 ``` private static ThreadLocal<Connection> connectionHolder = new ThreadLocal<>(); ``` 2. 在业务逻辑代码中获取Connection对象,并将其保存到ThreadLocal变量中。 ``` public static void beginTransaction() throws SQLException { Connection conn = getConnection(); conn.setAutoCommit(false); connectionHolder.set(conn); } ``` 3. 在需要执行事务的代码中获取ThreadLocal中保存的Connection对象,并使用它执行数据库操作。 ``` public static void update(String sql, Object... params) throws SQLException { QueryRunner runner = new QueryRunner(); Connection conn = connectionHolder.get(); runner.update(conn, sql, params); } ``` 4. 在事务结束时提交或回滚事务,并将Connection对象从ThreadLocal变量中清除。 ``` public static void commitTransaction() throws SQLException { Connection conn = connectionHolder.get(); conn.commit(); conn.close(); connectionHolder.remove(); } public static void rollbackTransaction() throws SQLException { Connection conn = connectionHolder.get(); conn.rollback(); conn.close(); connectionHolder.remove(); } ``` 这样就可以实现在多线程环境下安全地处理事务了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值