如题,我在学习《Flask Web开发:基于Python的Web应用开发实战》这本书第七章的时候,在shell中使用db.create_all()
创建sqlite数据库。但是发现这个命令只能创建出sqlite文件,不能创建数据库table
。
(venv) FlaskStudy$ python manage.py shell >>> from app import db >>> db.create_all()
几次尝试过后,发现如果在执行db.create_all()
前导入我创建的数据库模型,就能正常的创建出表了:
(venv) FlaskStudy$ python manage.py shell >>> from app import db >>> from app.models import User, Role >>> db.create_all()
或者在manage.py
中导入数据库模型也可以:
import os
from app import create_app, db
# 就是这一句
from app.models import User, Role
from flask.ext.script import Manager, Shell
from flask.ext.migrate import Migrate, MigrateCommand
app = create_app(os.getenv('FLASK_CONFIG') or 'default')
manager = Manager(app)
migrate = Migrate(app, db)
manager.add_command('db', MigrateCommand)
if __name__ == '__main__':
manager.run()
这是什么原理呢?求大神给讲解一下。
慕标琳琳