mysql savepoint 丢失_关于MySQL中savepoint语句使用时所出现的错误
前几天帮同事解决一个案例,在主从复制环境下,从库上的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语句使用时所出现的错误相关推荐
- mysql savepoint 什么意思_关于MySQL中savepoint语句使用时所出现的错误
前几天帮同事解决一个案例,在主从复制环境下,从库上的MySQL版本号是5.5.5,遇到下面的错误: #其他非相关信息我都隐藏掉了 [(yejr@imysql.com)]> show slave ...
- MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结
MySQL学习笔记_关于MySQL的字符类型VARCHAR长度知识总结 一.VARCHAR存储和行长度限制 1.VARCHAR(N)中,N指的是字符的长度,VARCHAR类型最大支持65535,指的是 ...
- mysql innodb引擎丢失_【MySQL】InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据...
注意!此方法只适用于innodb_file_per_table独立表空间的InnoDB实例. 此种方法可以恢复ibdata文件被误删.被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所 ...
- 删除+mysql+用户密码_误删除mysql中的所用用户,如何重新设置root账号和密码
在练习mysql语句的时候,使用delete将数据库中的所有用户删除了,其中也包括root用户.并进行了flush privileges:这时候发现重新登入mysql已经不能正常登陆.对此我们要重新设 ...
- mysql 显示用户_在Mysql中如何显示所有用户?
这是一个mysql初学者经常问到的一个问题,今天我们就带大家看看是如何在Mysql中显示所有用户的.通常我们在mysql中使用SHOW DATABASES可以显示所有的数据库,SHOW TABLES将 ...
- mysql 货币显示_在MySQL中以正确的格式显示USD货币记录
FORMAT()在MySQL中使用,以正确的格式显示USD货币记录.让我们首先创建一个表-mysql> create table DemoTable -> ( -> Amount D ...
- mysql select 区分大小写_在MySQL SELECT语句中实现区分大小写
SELECT默认情况下不区分大小写.对于区分大小写的实现,使用BINARY运算符.以下是语法:select *from yourTableName where BINARY yourColumnNam ...
- mysql binlog跟踪_在MySQL中使用init-connect与binlog来实现用户操作追踪记录
在MySQL中使用init-connect与binlog来实现用户操作追踪记录 分类: MySQL 前言: 测试环境莫名其妙有几条重要数据被删除了,由于在binlog里面只看到是公用账号删除的,无法查 ...
- mysql fulltext 分词_在mysql中使用全文索引fulltext|mysql,全文索引,fulltext
全文检索在 MySQL 中就是一个 FULLTEXT 类型索引.FULLTEXT 索引用于 MyISAM 表,可以在 CREATE TABLE 时或之后使用 ALTER TABLE 或 CREAT ...
最新文章
- the user operation is waiting for building workspace to complete解决办法
- cbow 和skip-gram比较
- java 反射 工厂_JAVA反射机制、工厂模式与SPRING IOC
- 信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1085:球弹跳高度的计算
- Codeforces Round #717 (Div. 2) D(倍增dp)
- # 异运算_小学数学运算三要点:定律、法则与顺序(解析)
- django-cbv与fbv
- 统计过去数据一个php脚本
- 普通人如何月入10万
- Docker部署Overleaf包含中文字体与全套texlive镜像
- Ubantu18.04
- Filter 过滤器的使用
- 基于S-FFT的相息图
- 最大似然估计,最大后验估计,贝叶斯估计联系与区别
- Qt文档阅读笔记-DTLS client解析
- Steam账号查询VAC封禁信息
- 个人春招记录贴,从年初的简历海投到现在的美团offer,我想告诉你的是这些......
- 一级b类计算机知识点,计算机等级考试(一级B)考试知识点
- 文本匹配(语义相似度)综述
- Jbd7:Spark
热门文章
- flask服务器端解析文件包时出现问题,flask + celery 遇到的那些坑
- 【Zookeeper进阶】大白话解释Zookeeper的选举机制
- php exec和query,关于Go SQL中的Query、Exec和Prepare使用对比(附网络抓包)
- python svm超参数_grid search 超参数寻优
- 计算机网络有限制,计算机网络中软件限制策略的应用规则有哪些
- 安全策略_实操教程丨使用Pod安全策略强化K8S安全
- atm java代码_用JAVA制作简单的ATM的代码 求教
- 操作系统ppt_Python处理PPT文件的实用姿势
- 计算机全球服务器,云计算的宿命:全球合并成一台计算机,支持无服务器运行...
- 使用函数求两个整数的最大公约数和最小公倍数