7

我正在尝试使这种多对多连接与 Flask-SQLAlchemy 和两个 MySQL 数据库一起工作,它非常接近,只是它为连接表使用了错误的数据库。这里是基础...

我有main_dbvendor_db。表设置为main_db.users, main_db.user_products(关系表),然后vendor_db.products。应该很清楚这些是如何连接的。

在我的 app.py 中,我正在设置这样的数据库:

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://user:pass@localhost/main_db'
app.config['SQLALCHEMY_BINDS'] = {
        'vendor_db': 'mysql://user:pass@localhost/vendor_db'
}

模型定义是这样设置的:

from app import db

# Setup relationship
user_products_tbl = db.Table('user_products', db.metadata,
        db.Column('user_id', db.Integer, db.ForeignKey('users.user_id')),
        db.Column('product_id', db.Integer, db.ForeignKey('products.product_id'))
)

class User(db.Model):
    __tablename__ = 'users'
    id = db.Column('user_id', db.Integer, primary_key=True)
    products = db.relationship("Product", secondary=user_products_tbl,
            backref="users", lazy="dynamic")

class Product(db.Model):
    __bind_key__ = 'vendor_db'
    __tablename__ = 'products'
    id = db.Column('product_id', db.Integer, primary_key=True)
    name = db.Column(db.String(120))

问题是,当我尝试获取用户的产品时,它试图vendor_db用于连接表而不是main_db. 有什么想法可以main_db改用它吗?我尝试设置另一个绑定main_db并设置info={'bind_key': 'main_db'}关系表定义,但没有运气。谢谢!

4

1 回答 1

12

原来我需要在这里做的是在我的user_products_tbl表定义中指定模式。所以,

user_products_tbl = db.Table('user_products', db.metadata,
        db.Column('user_id', db.Integer, db.ForeignKey('users.user_id')),
        db.Column('product_id', db.Integer, db.ForeignKey('products.product_id')),
        schema='main_db'
)

希望这对其他人有帮助!

于 2012-07-11T18:52:58.807 回答