Insert with execute many, 跳过外键约束失败的行

问题描述

我正在使用 Python MysqL.connector 。我必须做很多插入。我插入的数据很可能有一些行会导致外键约束失败,从而返回 1452 MysqL 错误

 add_specific="""
INSERT INTO `specific info type`
(`name`,`Classification Type_idClassificationType`)
VALUES
(%s,%s);
"""
cursor.executemany(add_specific,specific_info)

有没有一种方法可以执行所有插入操作,并且在 1452 的情况下,该示例将被跳过。我读过 executemany 效率更高,所以我更愿意使用它。我想我可以遍历所有示例并进行单独的插入并捕获异常。

解决方法

使用 INSERT IGNORE INTO whatever,MySQL 将忽略插入失败的行。