flask踩坑记录:flask_migrate迁移数据库出现 1050 “Table ‘xxxx‘ already exists“

模型新增字段后,用flask-sqlalchemy迁移数据库的时候总是出现"Table 'xxxx' already exists"的错误提示

这里记录下解决的过程:

从报错推测,问题的原因应该是迁移文件中的语句是cerate表,但是实际想要的只是增加几个字段

为什么每次生成的迁移文件都是创建表,而不是新增字段呢?看到一个文章中提到是数据库引擎的问题:https://blog.csdn.net/qq_38187188/article/details/105825964

最初 SQLALCHEMY_DATABASE_URI 配置的引擎是 mysqlconnector ,要换成其他的,比如 pymysql

换掉后删除以前生成的迁移文件,重新 init 、migrate、upgrade

python manager.py db init  # 初始化迁移文件
python manager.py db migrate  # 将模型添加到迁移文件
python manager.py db upgrade  # 迁移文件中的模型映射到数据库中

但是重新迁移的时候仍会出现Table already exists .......

经过仔细排查发现问题应该是出在模型类的  __tablename__ 属性上

我为模型类指定的名字是大写的,但实际数据库中的名字是小写的,所以每次生成迁移文件的时候才总create table

把模型类指定的表名改为小写,和数据库一致后,重新生成迁移文件,就能发现语句变了

再迁移到数据库时果然成功了

以上,浪费了几个小时总算没白费

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值