您好我的一些外键有问题。
我有这样的事情:
class Foo(db.Model):
"""The foo object."""
__tablename__ = 'foos_foo'
id = db.Column(db.Integer, primary_key=True)
title = db.Column(db.Text, unique=True)
content = db.Column(db.Text)
bar = db.relationship('Bar', backref='bars_bar')
bar_id = db.Column(db.Integer, db.ForeignKey('bars_bar.id'))
class Bar(db.Model):
"""The bar object."""
__tablename__ = 'bars_bar'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.Text, unique=True)
description = db.Column(db.Text)
status = db.Column(db.SmallInteger, default=NEW)
我使用此配置样式:https://github.com/mitsuhiko/flask/wiki/Large-app-how-to
所以我有这样的事情:
from app.foos.views import mod as foosModule
from app.bars.views import mod as barsModule
app.register_blueprint(foosModule)
app.register_blueprint(barsModule)
如果我在Mitsuhiko的配置样式中调用python shell.py,则出现此错误:
sqlalchemy.exc.OperationalError: (OperationalError) no such table: bars_bar u'SELECT bars_bar.id AS bars_bar_id, bars_bar.name AS bars_bar_name, bars_bar.description AS bars_bar_description, bars_bar.status AS bars_bar_status \nFROM bars_bar' ()
那里发生了什么?是的,桌子不存在,因为我会创建吗?有没有办法在其他一些表之前创建一些表?或者我错了什么?
谢谢你的时间!
答案 0 :(得分:3)
要创建初始数据库,只需从交互式Python shell导入db对象并运行SQLAlchemy.create_all()
方法来创建表和数据库:
from yourapplication import db
db.create_all()