欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

关于MySQL中savepoint语句使用时所出现的错误

程序员文章站 2024-02-28 10:31:16
前几天帮同事解决一个案例,在主从复制环境下,从库上的mysql版本号是5.5.5,遇到下面的错误: #其他非相关信息我都隐藏掉了 [(yejr@imysql....

前几天帮同事解决一个案例,在主从复制环境下,从库上的mysql版本号是5.5.5,遇到下面的错误:

#其他非相关信息我都隐藏掉了
 [(yejr@imysql.com)]> show slave status \g;
 slave_io_running: yes
 slave_sql_running: no
 last_errno: 1064
 last_error: error 'you have an error in your sql syntax; check the manual that corresponds to your mysql server version for the right syntax to use near '6e86db84_14847168f19__8000' at line 1' on query. default database: 'act'. query: 'savepoint 6e86db84_14847168f19__8000'
 last_io_errno: 0
 last_io_error:
 last_sql_errno: 1064
 last_sql_error: error 'you have an error in your sql syntax; check the manual that corresponds to your mysql server version for the right syntax to use near '6e86db84_14847168f19__8000' at line 1' on query. default database: 'act_log'. query: 'savepoint 6e86db84_14847168f19__8000'

第一感觉是遇到保留关键字了,不过看到这么长的字符串,不应该是保留关键字才对。
经过尝试,最后发现是字符串中的 “e” 这个字符如果存在就可能会报错,看起来应该是bug才对了。
在mysql的bug系统里确实找到了这个bug,不过看bug描述,在5.5版本中应该是已经修复了才对,看来太不靠谱了呀~~
关于这个bug:savepoint identifier is occasionally considered as floating point numbers

其实除了升级版本外,解决方法也很简单,把savepoint后面的 identifier 字符串用反引号(波浪号的下档键,英文叫做 backticks 键)引用起来就行。
例如:

savepoint `6e86db84_14847168f19__8000`;

这样就可以了。

这个案例也提示我们,在写sql时,涉及到数据库、表、字段、identifier 等名称时,最好是都能用反引号引用,确保可用。
曾经看到线上数据表有个字段名是 check ,这个名字在mysql里很早就已经是保留关键字,幸好开发同学比较靠谱,都加上了反引号。

关于savepoint的2个bug:
savepoint identifier should be enclosed with backticks
savepoint identifier is occasionally considered as floating point numbers