我设计了一个带有外键约束的大型数据库,以防止插入损坏的数据,这违反了这些约束。我希望,当我使用 Python 插入数据时,它会跳过外键约束失败的每个条目,以便仅将“真实”数据插入数据库中。有点像过滤器。但是,只要出现“损坏”条目,脚本就会停止。有没有办法强制他继续并跳过不需要的行?
感谢您的帮助!
最佳答案
您可以使用INSERT INTO ... SELECT ...
进行条件插入。举个例子:有两个表country和city,city
中的列country_id
引用了相应的来自国家的专栏。
国家/地区(country_id,名称)
城市(city_id、名称、country_id)
以下 INSERT
语句无条件插入条目。如果 country 中不存在值为 :country_id
的行,则会失败。
INSERT INTO city (city_id, name, country_id)
VALUES (:city_id, :name, :country_id);
如果国家中存在相应的行,则以下语句仅插入条目。否则,什么也不会发生。
INSERT INTO city (city_id, name, country_id)
SELECT :city_id, :name, :country_id
FROM country
WHERE country_id=:country_id;
关于Python:MySQL批量插入,跳过外键约束失败的条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19334585/