如何解决如何避免flask-alchemy和flask-admin创建先前删除的表?
我正在使用Flask-admin和Flask-sqlalchemy做一些测试。
为简化流程,我每次使用sqllite数据库在本地重新运行服务器时都会创建表
问题在于即使我从代码中删除了旧表,它也会加载旧表。就像某种缓存
代码非常简单:
models.py:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_admin import Admin
app = Flask(__name__)
sqlite_db = 'sqlite:///admin_db.db'
app.config['SQLALCHEMY_DATABASE_URI'] = sqlite_db
db = SQLAlchemy(app)
admin = Admin(app,template_mode='bootstrap3')
class Inverter(db.Model):
__tablename__ = "inverters"
id = db.Column(db.Integer,db.Sequence("inverters_id_seq"),primary_key=True)
name = db.Column(db.String,nullable=False,unique=True)
main.py:
from models import app,db,admin
from flask_admin.contrib.sqla import ModelView
from models import Inverter,["and other classes"]
admin.add_view(UpdateDateFieldsView(Inverter,db.session))
db.drop_all()
db.create_all()
if __name__ == '__main__':
app.run(debug=True)
即使我注释了所有与Inverter类有关的代码,它仍在被创建
我注意到drop_all()
似乎只删除了数据库中的映射表。先前删除的表不会被删除。 drop_all()
命令后的基数
我添加了一个db.reflect()
,似乎可以解决一半问题。 drop_all()立即删除所有表。但是create_all会创建代码中映射的表以及之前从代码中删除的Inverters表!
我应该运行另一个命令来避免这种行为吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。