Mysql实例关于MySQL中savepoint语句使用时所出现的错误
《Mysql实例关于MySQL中savepoint语句使用时所出现的错误》要点: 前几天帮同事办理一个案例,在主从复制环境下,从库上的MySQL版本号是5.5.5,遇到下面的错误:MYSQL应用 #其他非相关信息我都暗藏掉了 [(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' 第一感觉是遇到保留关键字了,不过看到这么长的字符串,不应该是保留关键字才对. 其实除了升级版本外,解决办法也很简单,把savepoint后面的 identifier 字符串用反引号(波浪号的下档键,英文叫做 backticks 键)引用起来就行. savepoint `6e86db84_14847168f19__8000`; 这样就可以了.MYSQL利用 这个案例也提示我们,在写SQL时,涉及到数据库、表、字段、identifier 等名称时,最好是都能用反引号引用,确保可用. 关于savepoint的2个bug: 欢迎参与《Mysql实例关于MySQL中savepoint语句使用时所出现的错误》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |