4
问题:需要将具有多重绑定的应用程序中的sqlalchemy自动映射到现有数据库的完整工作示例。在现有数据库周围烧瓶sqlalchemy示例
我想绑定到两个数据库,并有一个自动映射表。我需要这样做,因为我无法控制一个数据库,因此必须不断重新编写模型,并且每次迁移时都可能会删除新表。
我喜欢给出的答案here,但我似乎无法让它在Flask中工作(我可以使用sqlalchemy来查询每个例子)。
我在
EDIT设置从上面的结果的例子的model.py我把线
db.Model.metadata.reflect[db.engine]
从另一个交,并且它应该是db.Model.metadata.reflect (db.engine) 非常简单的解决方案
这里是我的model.py
from app import db
from sqlalchemy.orm import relationship
db.Model.metadata.reflect[db.engine]#change to (db.engine)
class Buildings(db.Model):
__table__ = db.Model.metadata.tables['test']
__bind_key__ = 'chet'
def __repr__(self):
return self.test1
.... other models from sqlalchemy uri here...
我得到这个
>>> from app import db, models
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "app/__init__.py", line 69, in <module>
from app import views, models
File "app/views.py", line 1, in <module>
from app import app,models, db
File "app/models.py", line 163, in <module>
db.Model.metadata.reflect[db.engine]
TypeError: 'instancemethod' object has no attribute '__getitem__'
这里是我的config.py
SQLALCHEMY_DATABASE_URI = 'postgresql://[email protected]/ubuntuweb'
SQLALCHEMY_BINDS = {
'chet': 'postgresql://[email protected]/warehouse',
}
这里是我的init.py文件
from flask import Flask
from flask_bootstrap import Bootstrap
from flask.ext.sqlalchemy import SQLAlchemy
from flask.ext.admin import Admin, BaseView, expose
from flask.ext.script import Manager
from flask.ext.migrate import Migrate, MigrateCommand
from flask.ext.login import LoginManager, UserMixin, login_required
app = Flask(__name__)
app.config['UPLOAD_FOLDER'] = 'app/static'
app.config.from_object('config')
db = SQLAlchemy(app)
migrate = Migrate(app, db)
manager = Manager(app)
manager.add_command('db', MigrateCommand)
Bootstrap(app)
from app import views, models
admin = Admin(app)
感谢您的帮助。我将硬括号从我帖子中的链接中拉出来,我的问题的一部分就是为什么答案有括号。它来自http://stackoverflow.com/questions/17652937/how-to-build-a-flask-application-around-an-already-existing-database“将声明基础绑定到引擎:db.Model.metadata .reflect [db.engine]“ –
@ChetMeinzer,因为答案是错误的。我将编辑现在纠正它。 –
@ChetMeinzer(你会注意到,顶级投票和接受的答案有正确的语法!:D) –