数据库中事务详解

简介: 数据库中事务详解

1. 事务的基本介绍


  1. 概念:
    * 如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。
  2. 操作:
    1. 开启事务: start transaction;
    2. 回滚:rollback;
    3. 提交:commit;
  3. 例子:
    CREATE TABLE account (
    id INT PRIMARY KEY AUTO_INCREMENT,
    NAME VARCHAR(10),
    balance DOUBLE
    );
    -添加数据
    INSERT INTO account (NAME, balance) VALUES (‘zhangsan’, 1000), (‘lisi’, 1000);
    SELECT * FROM account;
    UPDATE account SET balance = 1000;
    张三给李四转账 500 元
    – 0. 开启事务
    START TRANSACTION;
    – 1. 张三账户 -500
    UPDATE account SET balance = balance - 500 WHERE NAME = ‘zhangsan’;
    – 2. 李四账户 +500
    – 出错了…
    UPDATE account SET balance = balance + 500 WHERE NAME = ‘lisi’;
    – 发现执行没有问题,提交事务
    COMMIT;
    – 发现出问题了,回滚事务
    ROLLBACK;
  4. MySQL数据库中事务默认自动提交
    * 事务提交的两种方式:
    * 自动提交:
    * mysql就是自动提交的
    * 一条DML(增删改)语句会自动提交一次事务。
    * 手动提交:
    * Oracle 数据库默认是手动提交事务
    * 需要先开启事务,再提交
    * 修改事务的默认提交方式:
    * 查看事务的默认提交方式:SELECT @@autocommit; – 1 代表自动提交 0 代表手动提交
    * 修改默认提交方式: set @@autocommit = 0;


2. 事务的四大特征:


  1. 原子性:是不可分割的最小操作单位,要么同时成功,要么同时失败。
  2. 持久性:当事务提交或回滚后,数据库会持久化的保存数据。
  3. 隔离性:多个事务之间。相互独立。
  4. 一致性:事务操作前后,数据总量不变


3. 事务的隔离级别


  • 概念:多个事务之间隔离的,相互独立的。但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。
  • 存在问题:
  1. 脏读:一个事务,读取到另一个事务中没有提交的数据
  2. 不可重复读(虚读):在同一个事务中,两次读取到的数据不一样。
  3. 幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。
  • 隔离级别:
  1. read uncommitted:读未提交
  • 产生的问题:脏读、不可重复读、幻读
  1. read committed:读已提交 (Oracle)
  • 产生的问题:不可重复读、幻读
  1. repeatable read:可重复读 (MySQL默认)
  • 产生的问题:幻读
  1. serializable:串行化
  • 可以解决所有的问题
  • 注意:隔离级别从小到大安全性越来越高,但是效率越来越低
  • 数据库查询隔离级别:
  • select @@tx_isolation;
  • 数据库设置隔离级别:
  • set global transaction isolation level 级别字符串;


新创建一个公众号 Rockey小何同学 想相互交流的同学可以关注一下哈! 感谢支持!

相关文章
|
13天前
|
SQL 关系型数据库 数据库
事务隔离级别:保障数据库并发事务的一致性与性能
事务隔离级别:保障数据库并发事务的一致性与性能
|
13天前
|
算法 大数据 数据库
数据库事务:保障数据一致性的基石
数据库事务:保障数据一致性的基石
|
13天前
|
存储 SQL 关系型数据库
认识数据库中的事务机制
认识数据库中的事务机制
26 0
|
6天前
|
SQL 关系型数据库 MySQL
使用关系型数据库事务的例子
【5月更文挑战第12天】本文介绍了设置MySQL事务的三种方式:全局、当前session和下一个事务,并提供了示例代码展示如何开始事务和设置隔离级别。还简述了引擎设置和数据源DSN格式。最后,讨论了SQL优化策略,包括选择合适的存储引擎、优化字段数据类型、建立索引、避免全表扫描等。
31 4
使用关系型数据库事务的例子
|
6天前
|
存储 关系型数据库 MySQL
了解如何在关系型数据库中处理事务
【5月更文挑战第12天】数据库事务确保数据的ACID特性,即原子性、一致性、隔离性和持久性。它们用于一组操作,要么全部成功,要么全部不执行,防止数据不一致。MySQL的InnoDB存储引擎严格支持事务。MySQL默认隔离级别为REPEATABLE READ
32 3
|
13天前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】4、MySQL 事务学习
【MySQL 数据库】4、MySQL 事务学习
50 0
|
13天前
|
SQL Java 关系型数据库
数据库事务
数据库事务
31 0
|
13天前
|
关系型数据库 MySQL Go
数据库的事务操作
数据库的事务操作
|
13天前
|
SQL 关系型数据库 MySQL
11. 数据库的事务
11. 数据库的事务
|
13天前
|
关系型数据库 MySQL Go
数据库的事务操作 | 青训营
数据库的事务操作 | 青训营