关于在flask里面Model迁移的时候报错
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 *
在使用Flask的flask_migrate进行数据库迁移时遇到无法生成建表文件的问题,表现为migrations目录下的versions为空,提示No changes in schema detected。解决办法是在app的__init__.py或manage.py中导入所有models类。
1560

被折叠的 条评论
为什么被折叠?



