gpt4 book ai didi

Python:MySQL批量插入,跳过外键约束失败的条目

转载 作者:行者123 更新时间:2023-11-30 01:12:45 26 4
gpt4 key购买 nike

我设计了一个带有外键约束的大型数据库,以防止插入损坏的数据,这违反了这些约束。我希望,当我使用 Python 插入数据时,它会跳过外键约束失败的每个条目,以便仅将“真实”数据插入数据库中。有点像过滤器。但是,只要出现“损坏”条目,脚本就会停止。有没有办法强制他继续并跳过不需要的行?

感谢您的帮助!

最佳答案

您可以使用INSERT INTO ... SELECT ... 进行条件插入。举个例子:有两个表countrycitycity中的列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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com