Flask 重新向MySQL数据表中添加外键报错 IntegrityError

sqlalchemy.exc.IntegrityError: (pymysql.err.IntegrityError) (1452, 'Cannot add or update a child row: a foreign key constraint fails (`test1`.`#sql-13a8_a9`, CONSTRAINT `arti
cle_ibfk_2` FOREIGN KEY (`article_id`) REFERENCES `article_type` (`id`))')
[SQL: ALTER TABLE article ADD FOREIGN KEY(article_id) REFERENCES article_type (id)]
(Background on this error at: http://sqlalche.me/e/13/gkpj)

报错的原因如下:
1、需要引用外键的数据表中存在数据
2、在设计表格的属性的时候设置了不允许为空
因此存在冲突,创建表格失败。
这时可以将引用外键的数据表中的数据delete 掉就可以运行成功。(将数据表中的数据全部删掉的命令)

delete from tablename;

但是有可能又会报这样的错误

 Target database is not up to date.

这是因为我们上一次migrate后没有上传的原因
我们只需要将migrate生成的版本文件删掉(要注意看看数据表alembic_version中的版本号是不是已经被同步,如果被同步,就进行降级处理python app.py db downgrade),然后重新运行python app.py db migrate —> python app.py db upgrade这时候时候数据表即可生成

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值