美文网首页MYSQL
9.MySQL中的事务

9.MySQL中的事务

作者: Stone_説 | 来源:发表于2020-07-21 22:04 被阅读0次

目录:
1.事务的特性
2.事务的生命周期
3.事务的操作
4.事务的隔离级别

1. 事务的特特性

事务Transactions:一组原子性的SQL语句,或一个独立工作单元

事务日志:记录事务信息,实现undo,redo等故障恢复功能
ACID特性:
A: atomicity原子性;整个事务中的所有操作要么全部成功执行,要么全部失败后回滚
C: consistency一致性;数据库总是从一个一致性状态转换为另一个一致性状态
I: Isolation隔离性;一个事务所做出的操作在提交之前,是不能为其它事务所见;隔离有多种隔离级别,实现并发
D: durability持久性;一旦事务提交,其所做的修改会永久保存于数据库中

2. 事务的生命周期

Transaction生命周期.jpg

3. 事务的操作

启动事务

BEGIN
BEGIN WORK
START TRANSACTION

结束事务:

COMMIT:提交
ROLLBACK: 回滚
注意:只有事务型存储引擎中的DML语句方能支持此类操作
自动提交: set autocommit={1|0} 默认为1,为0时设为非自动提交
建议:显式请求和提交事务,而不要使用“自动提交”功能
事务支持保存点: savepoint
SAVEPOINT identifier
ROLLBACK [WORK] TO [SAVEPOINT] identifier
RELEASE SAVEPOINT identifier

4.事务的隔离级别

从上至下更加严格

READ UNCOMMITTED 可读取到未提交数据,产生脏读
READ COMMITTED 可读取到提交数据,但未提交数据不可读,产生不可重复读,即可读取到多个提交数据,导致每次读取数据不一致
REPEATABLE READ 可重复读,多次读取数据都一致,产生幻读,即读取过程中,即使有其它提交的事务修改数据,仍只能读取到未修改前的旧数据。
                此为MySQL默认设置
SERIALIZABILE 可串行化,未提交的读事务阻塞修改事务,或者未提交的修改事务阻塞读事务。导致并发性能差
MVCC: 多版本并发控制,和事务级别相关
事务隔离级别.jpg

指定事务隔离级别:

服务器变量tx_isolation指定,默认为REPEATABLE-READ,可在GLOBAL和
SESSION级进行设置
SET tx_isolation=''
    READ-UNCOMMITTED
    READ-COMMITTED
    REPEATABLE-READ
    SERIALIZABLE
服务器选项中指定
vim /etc/my.cnf
    [mysqld]
    transaction-isolation=SERIALIZABLE   注意这个和服务器变量名不一样

相关文章

  • 9.MySQL中的事务

    目录:1.事务的特性2.事务的生命周期3.事务的操作4.事务的隔离级别 1. 事务的特特性 事务Transacti...

  • 9.mysql排序

    排序 -- order by 字段 -- asc 从小到大排序,既升序 --desc 从大到小排序 ,既降序 se...

  • 9.MySQL索引

    索引 索引MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。因此,数据...

  • 9.MySQL索引

    索引(Index)是数据库技术中的一个重要概念与技术,也是MySQL的一个数据库对象。对与任何DBSM,索引都是查...

  • Java中的事务——JDBC事务和JTA事务

    本文来介绍一下J2EE中和事务相关的内容,在阅读本文之前,希望读者对分布式有一定的了解。 Java事务的类型有三种...

  • Java中的事务——全局事务与本地事务

    在上一篇文章中说到过,Java事务的类型有三种:JDBC事务、JTA(Java Transaction API)事...

  • Java中的事务——JDBC事务和JTA事务

    转载之前的事务介绍基本都是数据库层面的事务,本文来介绍一下J2EE中和事务相关的内容,在阅读本文之前,希望读者对分...

  • Java中的事务——JDBC事务和JTA事务

    转载:http://www.hollischuang.com/archives/1658 之前的事务介绍基本都是数...

  • Redis 事务

    相比关系型数据库中的事务模型,Redis 中事务要简单一些。Redis 中的事务不能保证原子性,也就是说,事务中某...

  • 9.MySQL查询优化

    1..需要注意字符串与整数之间的强制类型转换

网友评论

    本文标题:9.MySQL中的事务

    本文链接:https://www.haomeiwen.com/subject/ddswkktx.html