MySQL数据库的事务管理
2023-09-14 08:57:21 时间
当前在开发ERP系统,使用到的数据库为Mysql。下面介绍下如何开启事务,以及事务隔离的机制 :
1. 检查当前数据库使用的存储引擎。
show engines;
2. 修改前my.ini中的文件如下:
3. 修改my.ini的文件如下。
3.1 修改了默认的存储引擎
3.2 增加了mysql数据库的事务隔离级别, 如果不添加默认是REPEATABLE-READ.
4. 只需要重启mysql的服务即可。
net stop mysql
net start mysql
5. 再次查询show engines,显示如下
6. 事务隔离机制的说明,以下引用自别人的文章
- 未提交读(READ UNCOMMITTED)。另一个事务修改了数据,但尚未提交,而本事务中的SELECT会读到这些未被提交的数据(脏读)。
- 提交读(READ COMMITTED)。本事务读取到的是最新的数据(其他事务提交后的)。问题是,在同一个事务里,前后两次相同的SELECT会读到不同的结果(不重复读)。如两个会话a和b,由于是read committed所以只有当事务提交后才能被别的事务可见,当a执行查询后b执行插入,b执行commit提交事务,这时a再次查询结果确实不一样的,a的两次查询同属于一个事务,即为不可重复读。
- 可重复读(REPEATABLE READ)。在同一个事务里,SELECT的结果是事务开始时时间点的状态,因此,同样的SELECT操作读到的结果会是一致的。直到提交事务后再查询才可以看到其他事务在本事务执行期间锁进行的更改操作。在MySQL中InnoDB和XtraDB存储引擎通过多版本并发控制(MVCC)解决了幻读的问题。
- 串行化(SERIALIZABLE)。读操作会隐式获取共享锁,可以保证不同事务间的互斥。
-
SQL 事务隔离级别
在MySQL中默认事务隔离级别是可重复读(Repeatable read).可通过SQL语句查询:
查看InnoDB系统级别的事务隔离级别:mysql> SELECT @@global.tx_isolation;
在MySQL中默认事务隔离级别是可重复读(Repeatable read).可通过SQL语句查询:
mysql> set global transaction isolation level read committed;
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
mysql> create table test(i int) engine=innodb;
mysql> insert into test values(1);
Query OK, 1 row affected (0.00 sec)
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
查看InnoDB系统级别的事务隔离级别:
mysql> SELECT @@global.tx_isolation;
结果:
+-----------------------+
| @@global.tx_isolation |
+-----------------------+
| REPEATABLE-READ |
+-----------------------+
1 row in set (0.00 sec)
| @@global.tx_isolation |
+-----------------------+
| REPEATABLE-READ |
+-----------------------+
1 row in set (0.00 sec)
查看InnoDB会话级别的事务隔离级别:
mysql> SELECT @@tx_isolation;
结果:
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
修改事务隔离级别:
mysql> set global transaction isolation level read committed;
Query OK, 0 rows affected (0.00 sec)
mysql> set session transaction isolation level read committed;
Query OK, 0 rows affected (0.00 sec)
InnoDB 的可重复读隔离级别和其他数据库的可重复读是有区别的,不会造成幻象读(phantom read),所谓幻象读,就是同一个事务内,多次select,可以读取到其他session insert并已经commit的数据。下面是一个小的测试,证明InnoDB的可重复读隔离级别不会造成幻象读。测试涉及两个session,分别为 session 1和session 2,隔离级别都是repeateable read,关闭autocommit
mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
mysql> set autocommit=off;
Query OK, 0 rows affected (0.00 sec)
session 1 创建表并插入测试数据
mysql> create table test(i int) engine=innodb;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into test values(1);
Query OK, 1 row affected (0.00 sec)
session 2 查询,没有数据,正常,session1没有提交,不允许脏读
mysql> select * from test;
Empty set (0.00 sec)
mysql> select * from test;
Empty set (0.00 sec)
session 1 提交事务
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
session 2 查询,还是没有数据,没有产生幻象读
mysql> select * from test;
Empty set (0.00 sec)
当session2提交事务后才可以看到session1的插入数据;
以上试验版本:
mysql> select version();
+-------------------------+
| version() |
+-------------------------+
| 5.0.37-community-nt-log |
+-------------------------+
1 row in set (0.00 sec)
mysql> select * from test;
Empty set (0.00 sec)
当session2提交事务后才可以看到session1的插入数据;
以上试验版本:
mysql> select version();
+-------------------------+
| version() |
+-------------------------+
| 5.0.37-community-nt-log |
+-------------------------+
1 row in set (0.00 sec)
相关文章
- MySQL数据库管理工具_mysql数据库管理工具有哪些
- MySQL性能提升之路:分析性能障碍.(mysql性能分析)
- 使用 MySQL 数据库: 降低成本 增强性能(mysql数据库选择)
- 掌握MySQL:如何有效选择数据库(mysql怎么选择数据库)
- MySQL索引: 驱动数据库性能的前缀之道(mysql索引前缀)
- MySQL:处理中文字符串的技巧(mysql中文字符串)
- 通过MySQL二级考试的秘诀(mysql二级考试)
- 探究数据库MySQL性能:运行状态检查(查看mysql运行状态)
- MySQL揭示:如何获取数据库名称(mysql获取数据库名)
- MySQL数据库文档的自动生成指南(mysql数据库文档生成)
- 深入探索MySQL数据库引擎的优势和适用场景(mysql数据库引擎)
- MySQL中文官网:解析数据库神器的中文版指南(mysql 中文官网)
- 坚持自学,破解MySQL之路(mysql自学网)
- MySQL配置指南:一步步跟着做!(mysql的配置向导)
- MySQL数据库上传新奇的工具(mysql数据库上传工具)
- MySQL中删除数据库的步骤(mysql如何删除数据库)
- MySQL中使用XOR运算符优化查询条件(mysql中xor)
- MySQL路径池C语言拥抱互联网(c mysql路径池)
- MySQL下载安装界面下载完成,安装开始(mysql下载完成界面)
- MySQL目录设置详解(mysql下目录设置)
- MySQL三大知识,让你成为数据库高手(mysql三大知识)
- 快速增加MYSQL数据库连接数负载能力的方法分享
- MySQL数据库操作常用命令小结