MySQL Error number: MY-011960; Symbol: ER_IB_MSG_135; SQLSTATE: HY000 报错 故障修复 远程处理


文档解释

Error number: MY-011960; Symbol: ER_IB_MSG_135; SQLSTATE: HY000

Message: %s

错误说明

ER_IB_MSG_135是MySQL的系统错误码,它的原因指的是用户在尝试操作表时引起的,表的定义不满足InnoDB的限制。这是一个常见的错误,当一个用户尝试在MySQL中进行INSERT、UPDATE、DELETE或其他任何更新或查询操作时可能会发生。

常见案例

ER_IB_MSG_135可能会出现在以下情况:

1. 如果字段超出60个字节,它可能会引发ER_IB_MSG_135错误;

2. 尝试使用错误的数据类型去定义表会抛出ER_IB_MSG_135错误;

3. 尝试发现唯一字段索引时,而在此之前已经存在一个不同的索引会引发ER_IB_MSG_135错误;

4. 如果在InnoDB表中使用了一些在其他存储引擎中不允许使用的特殊字符,可能会出现ER_IB_MSG_135错误;

5. 如果在列定义中使用了多个无效字符,则ER_IB_MSG_135可能会出现。

解决方法

要解决 ER_IB_MSG_135 错误,最佳做法是查看Mysql服务器上,产生这个错误的SQL语句,并对其进行检查。检查SQL语句时,要弄清楚以下内容:

1. 数据表是否满足InnoDB的要求:查看字段的大小是否溢出,数据类型是否正确以及是否存在冲突的索引;

2. 如果新建表时出现ER_IB_MSG_135错误,要检查CREATE TABLE语句是否正确,并且不要使用不允许使用的特殊字符;

3. 对ALTER TABLE语句进行检查,以确定是否使用了与已有结构冲突的新列定义;

4. 对所有字段中长度大于60个字符的字段进行检查,以检查是否有数据长度超出范围;

5. 对INSERT语句中提供的值进行检查,检查是否为该字段提供了过长或过短的值,而且要确保数据与字段类型相匹配;

6. 如果在多个列写入查询中发现了ER_IB_MSG_135错误,要检查提供的列名和值的数量是否相等。

最后,在确认SQL语句的改正后,再次尝试重新运行SQL语句。如果仍然发生ER_IB_MSG_135错误,则可以重置MySQL并重新启动服务,以清理所有缓存数据并重新引导数据库,以解决ER_IB_MSG_135错误。