前几天帮同事解决一个案例,在主从复制环境下,从库上的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

您可能感兴趣的文章:MySQL的主从复制步骤详解及常见错误解决方法安装Mysql时出现错误及解决办法PHP错误Warning:mysql_query()解决方法mysql中一个普通ERROR 1135 (HY000)错误引发的血案分享一下Mysql常见的几个错误问题及解决方法MySQL下PID文件丢失的相关错误的解决方法MySQL导入sql脚本错误:2006 解决方法MySQL错误ERROR 1615 解决方法MySQL错误Forcing close of thread的两种解决方法MySQL命令行界面中出现字符错误提示的原因及解决方法

mysql savepoint 丢失_关于MySQL中savepoint语句使用时所出现的错误相关推荐

  1. mysql savepoint 什么意思_关于MySQL中savepoint语句使用时所出现的错误

    前几天帮同事解决一个案例,在主从复制环境下,从库上的MySQL版本号是5.5.5,遇到下面的错误: #其他非相关信息我都隐藏掉了 [(yejr@imysql.com)]> show slave ...

  2. MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结

    MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结 一.VARCHAR存储和行长度限制 1.VARCHAR(N)中,N指的是字符的长度,VARCHAR类型最大支持65535,指的是 ...

  3. mysql innodb引擎丢失_【MySQL】InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据...

    注意!此方法只适用于innodb_file_per_table独立表空间的InnoDB实例. 此种方法可以恢复ibdata文件被误删.被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所 ...

  4. 删除+mysql+用户密码_误删除mysql中的所用用户,如何重新设置root账号和密码

    在练习mysql语句的时候,使用delete将数据库中的所有用户删除了,其中也包括root用户.并进行了flush privileges:这时候发现重新登入mysql已经不能正常登陆.对此我们要重新设 ...

  5. mysql 显示用户_在Mysql中如何显示所有用户?

    这是一个mysql初学者经常问到的一个问题,今天我们就带大家看看是如何在Mysql中显示所有用户的.通常我们在mysql中使用SHOW DATABASES可以显示所有的数据库,SHOW TABLES将 ...

  6. mysql 货币显示_在MySQL中以正确的格式显示USD货币记录

    FORMAT()在MySQL中使用,以正确的格式显示USD货币记录.让我们首先创建一个表-mysql> create table DemoTable -> ( -> Amount D ...

  7. mysql select 区分大小写_在MySQL SELECT语句中实现区分大小写

    SELECT默认情况下不区分大小写.对于区分大小写的实现,使用BINARY运算符.以下是语法:select *from yourTableName where BINARY yourColumnNam ...

  8. mysql binlog跟踪_在MySQL中使用init-connect与binlog来实现用户操作追踪记录

    在MySQL中使用init-connect与binlog来实现用户操作追踪记录 分类: MySQL 前言: 测试环境莫名其妙有几条重要数据被删除了,由于在binlog里面只看到是公用账号删除的,无法查 ...

  9. mysql fulltext 分词_在mysql中使用全文索引fulltext|mysql,全文索引,fulltext

    全文检索在 MySQL 中就是一个 FULLTEXT 类型索引.FULLTEXT 索引用于   MyISAM 表,可以在 CREATE TABLE 时或之后使用 ALTER TABLE 或 CREAT ...

最新文章

  1. the user operation is waiting for building workspace to complete解决办法
  2. cbow 和skip-gram比较
  3. java 反射 工厂_JAVA反射机制、工厂模式与SPRING IOC
  4. 信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1085:球弹跳高度的计算
  5. Codeforces Round #717 (Div. 2) D(倍增dp)
  6. # 异运算_小学数学运算三要点:定律、法则与顺序(解析)
  7. django-cbv与fbv
  8. 统计过去数据一个php脚本
  9. 普通人如何月入10万
  10. Docker部署Overleaf包含中文字体与全套texlive镜像
  11. Ubantu18.04
  12. Filter 过滤器的使用
  13. 基于S-FFT的相息图
  14. 最大似然估计,最大后验估计,贝叶斯估计联系与区别
  15. Qt文档阅读笔记-DTLS client解析
  16. Steam账号查询VAC封禁信息
  17. 个人春招记录贴,从年初的简历海投到现在的美团offer,我想告诉你的是这些......
  18. 一级b类计算机知识点,计算机等级考试(一级B)考试知识点
  19. 文本匹配(语义相似度)综述
  20. Jbd7:Spark

热门文章

  1. flask服务器端解析文件包时出现问题,flask + celery 遇到的那些坑
  2. 【Zookeeper进阶】大白话解释Zookeeper的选举机制
  3. php exec和query,关于Go SQL中的Query、Exec和Prepare使用对比(附网络抓包)
  4. python svm超参数_grid search 超参数寻优
  5. 计算机网络有限制,计算机网络中软件限制策略的应用规则有哪些
  6. 安全策略_实操教程丨使用Pod安全策略强化K8S安全
  7. atm java代码_用JAVA制作简单的ATM的代码 求教
  8. 操作系统ppt_Python处理PPT文件的实用姿势
  9. 计算机全球服务器,云计算的宿命:全球合并成一台计算机,支持无服务器运行...
  10. 使用函数求两个整数的最大公约数和最小公倍数