MySQL Error number: MY-010382; Symbol: ER_GTID_ALREADY_ADDED_BY_USER; SQLSTATE: HY000

文档解释

Error number: MY-010382; Symbol: ER_GTID_ALREADY_ADDED_BY_USER; SQLSTATE: HY000

Message: The transaction owned GTID is already in the %s table, which is caused by an explicit modifying from user client.

错误说明

MY-010382(ER_GTID_ALREADY_ADDED_BY_USER)是MySQL的一个错误代码,这个错误一般出现在MySQL中试图使用多个用户使用事务时被拒绝,表示已被其它用户添加过。此时MySQL由于所请求的操作是安全不可改变或更改的,因此拒绝执行并产生此错误。

常见案例

1. 在MySQL中,一个用户试图开始一个事务,但发现另一个用户已经使用了相同的GTID(全局事务ID )开始了一个事务,这时由于GTID 已经被另一个用户使用,因此在尝试开始一个新的事务时就会产生MY-010382 (ER_GTID_ALREADY_ADDED_BY_USER)的错误。

2. 如果 MySql的事务复制功能被启用,当一个用户尝试在复制线程中启动一个事务时,该用户就会遇到此错误,因为MySQL从一台服务器复制不同事务时会使用GTID,如果同一GTID或者UUID已经被另一台 MySql服务器使用,则会出现MY-010382 ( ER_GTID_ALREADY_ADDED_BY_USER) 错误。

解决方法

1.如果不是使用Replication,可以忽略该错误,并等待系统执行完当前请求。

2.如果使用了Replication,可以关闭Replication,在Replication服务上运行一个flush_gtids,该操作将清除任何重复的事务ID,不过,该操作将耗费一定的时间和计算资源,因此在执行之前应进行计算考虑。

3.最后,您也可以尝试使用set @@ global.gtid_ignore_duplicates=1 来使MySQL可以忽略任何重复的 tansaction_id,如果您确定传输的数据是正确的,这将是一个比较好的选择。

你可能感兴趣的