Flask使用flask_migrate中的migrate命令以及flask_sqlalchemy无法生成建表文件的原因,提示:INFO [alembic.env] No changes in schema detected.

问题:我是新建一个项目,然后拆分,发现生成不了建表文件。

运行python manage.py db init 可以生成文件夹

运行python manage.py db migrate 无法生成建表文件, migrations文件夹下的versions为空,而且提示INFO [alembic.env] No changes in schema detected.

导致我们没办法迁移文件,同时在windows下还会报一个

Warning: (1366, "Incorrect string value: '\\xD6\\xD0\\xB9\\xFA\\xB1\\xEA...' for column 'VARIABLE_VAL
UE' at row 484")
result = self._query(query)警告,估计是Windows默认编码为GBK,所致,这个并不是无法生成建表文件的原因。

解决方法:我在网上找了好久,最后在 https://www.2cto.com/net/201610/559848.html这里找到了原因,是由于‘原来flask-migrate是检测上下文中db.Model的子类来创建表的..’,所有我们必须让这个app能够知道有这个models文件的存在,所以,在app的文件夹里的__init__文件夹中加上,因为我们在manage.py中导入app中的文件时,会自动导入__init__.py文件夹,或者在manage.py中导入也行

在__init__.py 或者manage.py  中导入models里面的所有类

from App.models import *   

这一句话,就可以顺利生成建表文件以及表结构了。

注意:如果之前有migrate文件夹,需要先将migrate文件夹删除,重新生成init -->migrate -->upgrade

 

posted @ 2018-07-07 10:02  留雁  阅读(3043)  评论(2编辑  收藏  举报