MySQL QA 解析binlog的两个问题

news/2024/7/23 23:21:36 标签: 数据库

连续碰到两个同学问类似的问题,必须要记录一下。

 

问题:

    一个作解析binlog应用的同学发现不论用utf8还是gbk来解析binlog都可能会碰到无法解析的语句,因为有些用户会用utf8,有些用gbk。尤其在处理Query类型的SQL语句中的中文字符,比如建表语句中的中文注释。

     于是他想到用mysqlbinlog来看看binlog里面的内容。

     Mysqlbinlog这个工具的结果带来了新的疑问。

       开一个客户端,执行序列如下:

      set names utf8;

      create table a(c int);

      create table b(c int);

      set names gbk;

      drop table a;

      create table a(c int)comment='测试字符集';

  mysqlbinlog解析结果如下

    binlog的结果与预期相同。从结果看,可以通过

SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=28/*!*/;

 

    这句话的原始信息中得到当前使用的字符集,那么解析后续的binlog语句就没有问题。可以看到在drop table a之前我们修改了字符集,同样在binlog解析结果中可以看到一个设置字符集的语句。

 

     问题追问:但是解析工具是可以指定起始位置的。如果指定从drop table a这个语句的位置之后开始解析,那是不是就无法得知当前的字符集信息(gbk)?是不是只能到MySQL server里面才能得到这个表的正确建表语句?

 

    显然不会这么复杂,否则MySQL的从库上执行一个change master 改变同步位置的时候,从库应该使用什么字符集呢?碰到的问题是相同的。

    实际上,对于statement格式的binlog(类型为QUERY_EVENT)每个event中都记录了当前使用的字符集编号。无论主库、从库还是mysqlbinlog,都保存相同的一份编号到字符集的对应,能够决定使用什么字符集来解析binlog中的字符串。

    这里也可以得到为什么官方无法保证从库版本低于主库版本的主从结构正确性的一个原因。

     至于为什么mysqlbinlog工具不会每行都输出当前使用的字符集?其实有点洁癖的程序员都会这么干的吧,当前的语句与上一个语句使用相同的环境变量,就不重复输出了。

 

问题2mysqlbinlog结果中有use一个db以后,执行多个语句,此时mysqlbinlog的结果中看到,只会在切换的时候显示一次use db。那如果从之后的第二个语句开始解析binlog,会不会导致这些语句执行到另外一个库去?

同理。


http://www.niftyadmin.cn/n/1339903.html

相关文章

data parallel, model parallel,GPU显存不足怎么办?动态图显存优化

pytorch(分布式)数据并行个人实践总结——DataParallel/DistributedDataParallel DataParallel & DistributedDataParallel分布式训练 【深度学习】— 分布式训练常用技术简介 GPU显存不足怎么办 MegEngine 中动态图显存优化(DTR)的实现与优化

Qt QTextEdit 使用拖放、复制、粘贴进行文本或图像的插入

使用QTextEdit建立一个简单地文本编译器,可以实现文字和图片的混编。 插入文字当然没什么问题,QTextEdit也直接可以复制粘贴文字。但是对于插入图片怎么办呢? 方案一:单击一个按钮,选择一张图片,将图片插入…

thread-safety PHP no thread-safety PHP 版本选择

不同的web服务器处理高并发的HTTP请求的方式是不同的。一个相对流行的方式是使用线程处理请求——web服务器为每一个请求创建/销毁一个线程。Apache HTTP web服务器使用worker MPM支持多线程模型处理请求。Apache也支持使用prefork MPM,用进程来处理并发的请求——-…

单调栈notebook

文章目录[739. 每日温度](https://leetcode-cn.com/problems/daily-temperatures/)小结[496. 下一个更大元素 I](https://leetcode-cn.com/problems/next-greater-element-i/)小结[503. 下一个更大元素 II](https://leetcode-cn.com/problems/next-greater-element-ii/)小结[42…

QT QTextEdit 限制最大输入长度

方式一(当QTextEdit只包含文字的时候适用): 连接QTextEidt 的 信号 void textChanged()到槽函数 void on_textEdit_textChanged() void MainWindow::on_textEdit_textChanged() {QString textContent ui->textEdit->toPlainText();in…

动态规划notebook

文章目录[63. 不同路径 II](https://leetcode-cn.com/problems/unique-paths-ii/)小结[343. 整数拆分](https://leetcode-cn.com/problems/integer-break/)小结[139. 单词拆分](https://leetcode-cn.com/problems/word-break/)小结[213. 打家劫舍 II](https://leetcode-cn.com/…

QT QTabWidget stylesheet 样式表

QTabWidget::pane /* The tab widget frame */ {top:20px;border:none;}QTabBar::tab:first /*第一个页面上面的标签tab*/ {color:#333333;background:transparent;font-family:"微软雅黑";font-size:14px;padding-left:-9px;padding-right:-9px;width:105px;heig…

QT 判断鼠标是否在某个控件上

if(!ui->scoreStandardBtn->geometry().contains(this->mapFromGlobal(QCursor::pos())));