MySQL记录非事务性语句-疑问

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

 MySQL 版本:mariadb 5.5.30

   OS版本: centos 5.6 x86_64

   摘自网络一段话:“事务是按照提交的顺序写入binlog内,MySQLserver 为区分不同的线程的语句,为每个线程都保持一个事务缓存,事务中执行的每个语句都放在事务缓存中,然后事务缓存的内容被复制到binlog中,且在事务提交时被清空。”

   以上这句话我是认同的,下面我们探讨下binlog如何记录非事务性语句;

   当没有事务活动时,非事务性语句会被直接写入binlog里面而不需要经过事务缓存;

   如果一个事务是活动的,可分为下面的情况处理:

   1、语句被标记为事务的,则被写入事务缓存(这句话不需要验证)

   2、语句没有被标记为事务性的,而且事务缓存中没有语句(即该语句作为事务的开头),则该语句被直接写入binlog;

   验证过程: 

   MyISAM 表: not_trans;  Innodb 表:trans; 

195934733.png

   commit;之后;验证binlog是否有 insert into not_trans 记录

   对于 binlog format: mixed 和 为statement的时候 都会有该记录;所以第二种情况是正确的

   3、语句未被标记为事务性的,但事务缓存中有该事务的其他语句,则该语句被写入事务缓存

   验证过程: 对事务性表和非事务性表 放在一个事务中,插入后不进行commit 而是进行 rollback操作(注:此时根据会提示warning,非事务性表无法回滚),此时按照第三种情况来说,binlog里面应该没有任何binlog记录;

   MyISAM 表: not_trans;  Innodb 表:trans;

200549392.png

   查看binlog进行验证:

   对于binlog mixed  和statement 格式存储, binlog里面都会有 非事务性语句的记录,并且后面是 rollback结尾;

   我觉得第三种情况是错误的,(对于这次测试有什么疑问大家可以共同探讨)

   补充:第三种情况 非事务性语句也许已经写入到事务缓存中,但由于在本实验中rollback失败,所以非事务性语句直接写入到binlog中;或许是非事务性语句根本就没写入到事务缓存中,未排除这两种可能,各位有什么方法来验证下吗?

   这个时候我们要提一下MySQL的一个相关参数:binlog_direct_non_transactional_updates

   首先这个是让非事务性的语句直接写入到binlog里面,但该参数有些鸡肋啦。在binlog format 为 statement的时候,该参数能起到作用,目前和版本没有关系;但在MySQL 5.5.5之后的版本,对于binlog format 为 mixed 或者 row 模式的情况下,该参数对binlog 是没有任何影响的!(大多数人使用的是mixed模式吧)






本文转自 位鹏飞 51CTO博客,原文链接:http://blog.51cto.com/weipengfei/1206939,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
|
1月前
|
SQL 安全 关系型数据库
【MySQL实战笔记】03.事务隔离:为什么你改了我还看不见?-01
【4月更文挑战第6天】MySQL事务的隔离性确保数据操作的完整性和一致性,ACID原则包括原子性、一致性、隔离性和持久性。事务隔离级别有四种:读未提交、读提交、可重复读和串行化,分别解决并发问题如脏读、不可重复读和幻读。不同隔离级别在效率和安全性间权衡,例如读未提交允许未提交变更可见,而串行化通过锁保证安全但可能降低效率。在不同隔离级别下,事务看到的数据状态会有所变化,例如在可重复读级别,事务始终看到初始数据,而在串行化级别,事务会等待其他事务完成再继续,避免数据冲突。
278 10
|
1天前
|
SQL 存储 关系型数据库
MySQL索引及事务
MySQL索引及事务
10 2
|
1天前
|
存储 算法 关系型数据库
MySQL事务与锁,看这一篇就够了!
MySQL事务与锁,看这一篇就够了!
|
1天前
|
Java 关系型数据库 MySQL
MySQL 索引事务
MySQL 索引事务
12 0
|
9天前
|
SQL 安全 关系型数据库
【Mysql-12】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】
【Mysql-12】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】
|
11天前
|
存储 关系型数据库 MySQL
Mysql学习--深入探究索引和事务的重点要点与考点
Mysql学习--深入探究索引和事务的重点要点与考点
|
12天前
|
存储 SQL 关系型数据库
Mysql_数据库事务
Mysql_数据库事务
|
13天前
|
缓存 关系型数据库 MySQL
【专栏】提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理
【4月更文挑战第27天】本文探讨了提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理。通过合理使用B-Tree和哈希索引,避免过度索引,以及优化查询语句和利用查询缓存,可以改善性能。事务管理中,应减小事务大小并及时提交,以保持系统效率。主从或双主复制可增强高可用性。综合运用这些方法,并根据实际需求调整,是优化MySQL的关键。
|
14天前
|
Java 关系型数据库 MySQL
{MySQL}索引事务和JDBC
{MySQL}索引事务和JDBC
21 0