最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQLQ&A解析binlog的两个有关问题

来源:动视网 责编:小采 时间:2020-11-09 13:34:22
文档

MySQLQ&A解析binlog的两个有关问题

MySQLQ&A解析binlog的两个有关问题:MySQL QA 解析binlog的两个问题 连续碰到两个同学问类似的问题,必须要记录一下。 问题: 。 一个作解析 binlog 应用的同学发现不论用 utf8 还是 gbk 来解析 binlog 都可能会碰到无法解析的语句,因为有些用户会用 utf8 ,有些用 gbk 。尤其在
推荐度:
导读MySQLQ&A解析binlog的两个有关问题:MySQL QA 解析binlog的两个问题 连续碰到两个同学问类似的问题,必须要记录一下。 问题: 。 一个作解析 binlog 应用的同学发现不论用 utf8 还是 gbk 来解析 binlog 都可能会碰到无法解析的语句,因为有些用户会用 utf8 ,有些用 gbk 。尤其在


MySQL QA 解析binlog的两个问题 连续碰到两个同学问类似的问题,必须要记录一下。 ? 问题: ??? 一个作解析 binlog 应用的同学发现不论用 utf8 还是 gbk 来解析 binlog 都可能会碰到无法解析的语句,因为有些用户会用 utf8 ,有些用 gbk 。尤其在处理 Query

MySQL Q&A 解析binlog的两个问题

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

?

问题:

??? 一个作解析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工具不会每行都输出当前使用的字符集?其实有点洁癖的程序员都会这么干的吧,当前的语句与上一个语句使用相同的环境变量,就不重复输出了。

?

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

同理。

?

?

文档

MySQLQ&A解析binlog的两个有关问题

MySQLQ&A解析binlog的两个有关问题:MySQL QA 解析binlog的两个问题 连续碰到两个同学问类似的问题,必须要记录一下。 问题: 。 一个作解析 binlog 应用的同学发现不论用 utf8 还是 gbk 来解析 binlog 都可能会碰到无法解析的语句,因为有些用户会用 utf8 ,有些用 gbk 。尤其在
推荐度:
标签: 两个 问题 解析
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top