mysql中事务以及事务隔离问题

目录

mysql的事务

  MySQL中的事务

 转账中的事务问题

 1.2  事务的特性

 1.3事务的隔离级别

mysql的事务

事务:事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么前部不成功

 

 

  MySQL中的事务

a.mysql引擎是支持事务的

b.mysql默认自动提交事务。每条语句都处在单独的事务中。

c.手动控制事务

开启事务:start transaction |begin

提交事务:commit

回滚事务:rollback

setAutoCommit(boolean autoCommit):将此连接的自动提交模式设置为给定的状态。

autoCommit - true启用自动提交模式; false禁用它

commit():使自上次提交/回滚永久释放任何数据库锁的 Connection对象目前持有的所有更改。

rollback():撤消所有更改在当前事务并释放任何数据库锁的 Connection对象目前持有。

 

 转账中的事务问题

中途抛出zero异常  aaa扣钱,但是bbb不加钱
/**
 * author:Simple
 * description:事务演示
 * 希望我们都能在以后昏暗的日子里熠熠生辉
 */
public class TestTranscation {
    @Test
    public void test1() {
        Connection connection = null;
        PreparedStatement preparedStatement = null;
        try {
            //1.加载驱动获取连接
            connection = DBUTils.getConnection();
            //2.创建执行对象并编写sql
            preparedStatement = connection.prepareStatement("UPDATE account SET money=money-100 WHERE NAME='aaa'");
            //3.执行sql语句
            preparedStatement.executeUpdate();
            int i=10/0;//此时出现一个异常问题,就是一个事务问题

            preparedStatement=connection.prepareStatement("UPDATE account SET money=money+100 WHERE NAME='bbb'");
            preparedStatement.executeUpdate();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            //4.释放资源

            DBUTils.closeAll(null,preparedStatement,connection);
        }
        System.out.println("执行结束");
    }
}

 1.2  事务的特性

原子性:指事务是一个不可分隔的工作单位,事务中的操作要么都发送,要么都不发生

一致性:事务必须使数据库从一个一致性状态变换到另外一个一致性状态,转帐前和转账后的总金额不变

隔离性:事务的隔离性是多个用户并发访问数据库时,数据库为每个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离

持久性:指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响 事务的ACID事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)

 1.3事务的隔离级别

赃读:指一个事务提交了另一个事务未提交的数据

不可重复读:在一个事务内读取表中的某一行数据,多次读取结果不同。一个事务读取到了另一个事务提交后的数据(update)

虚读(幻读):是指在一个事务内读取到了别的事务插入的数据,导致前后读取不一致(insert)

数据库通过设置事务的隔离级别防止以上情况的发生: 1.READ UNCOMMITED 赃读,不可重复读、虚读都有可能发生

2.READ COMMITTED 避免赃读。不可重复读、虚读都有可能发生(Oracle默认的)

4.REPEATABLE READ 避免赃读、不可重复读。虚读有可能发生(mysql默认)

8.SERIALIZABLE 避免赃读、重复读、虚读 级别越高,性能越低,数据越安全

mysql中: 查看当前的事务隔离级别:SELECT @@TX_ISOLATION;

更改当前的事务隔离级别:SET TRANSACTION ISOLATION LEVEL 四个级别之一。 设置隔离级别必须在事务之前

 

 

 

 

 

 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL事务隔离是数据库事务处理的一个关键概念,它用于控制并发访问数据库时的一致性。事务隔离级别定义了不同用户在同一时间对数据的操作如何互相影响。MySQL提供了几种不同的事务隔离级别: 1. **读未提交(READ UNCOMMITTED)**:这是最低的隔离级别,事务可以读取其他事务未提交的数据,可能导致脏读(读取到的是未提交更新的数据)和幻读(查询结果因其他事务的插入或删除而改变)。 2. **读已提交(READ COMMITTED)**:在此级别,事务只能看到已经提交的变更。这防止了脏读,但仍然可能面临不可重复读(由于其他事务的更新,相同的查询返回不同的结果)。 3. **可重复读(REPEATABLE READ)**:在此模式下,事务在其整个生命周期内不会看到其他事务对其已锁定行的更改,这保证了事务隔离性和一致性,但是可能出现幻读(如果另一个事务在该事务范围内插入了新行)。 4. **串行化(SERIALIZABLE)**:这是最高的隔离级别,保证了每个事务好像在单独使用数据库一样执行,完全避免了并发冲突,但性能开销最大。 选择哪个隔离级别取决于应用的具体需求。例如,如果对数据一致性要求很高,会选择可重复读或串行化,但如果希望提高并发性能,可能会接受较低级别的隔离,但可能需要更复杂的并发控制策略。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值