在SQLALchemy中如何在具有多个连接路径的表上建立双向关系?

2024-05-15 22:29:51 发布

您现在位置:Python中文网/ 问答频道 /正文

sqlalchemy documentation中给出的例子是

from sqlalchemy import Integer, ForeignKey, String, Column
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship

Base = declarative_base()

class Customer(Base):
    __tablename__ = 'customer'
    id = Column(Integer, primary_key=True)
    name = Column(String)

    billing_address_id = Column(Integer, ForeignKey("address.id"))
    shipping_address_id = Column(Integer, ForeignKey("address.id"))

    billing_address = relationship("Address", foreign_keys=[billing_address_id])
    shipping_address = relationship("Address", foreign_keys=[shipping_address_id])

class Address(Base):
    __tablename__ = 'address'
    id = Column(Integer, primary_key=True)
    street = Column(String)
    city = Column(String)
    state = Column(String)
    zip = Column(String)

我正在尝试一个类似的示例(这里不能放置这么多代码),如果我执行类似的操作,它将不起作用:

from sqlalchemy import Integer, ForeignKey, String, Column
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import relationship

Base = declarative_base()

class Customer(Base):
    __tablename__ = 'customer'
    id = Column(Integer, primary_key=True)
    name = Column(String)

    billing_address_id = Column(Integer, ForeignKey("address.id"))
    shipping_address_id = Column(Integer, ForeignKey("address.id"))

    billing_address = relationship("Address", foreign_keys=[billing_address_id], back_populates('bill_addr'))
    shipping_address = relationship("Address", foreign_keys=[shipping_address_id], back_populates('ship_addr'))

class Address(Base):
    __tablename__ = 'address'
    id = Column(Integer, primary_key=True)
    street = Column(String)
    city = Column(String)
    state = Column(String)
    zip = Column(String)

    bill_addr = relationship("Customer", back_populates('billing_address'))
    ship_addr = relationship("Customer", back_populates('shipping_address'))

我有两个疑问:
问题1)上述关系是双向的吗?
Q2)如何在具有多个连接路径的表之间建立双向关系?你知道吗

编辑: 在我的情况下,我得到以下错误:

sqlalchemy.exc.AmbiguousForeignKeysError
sqlalchemy.exc.AmbiguousForeignKeysError: Could not determine join condition between parent/child tables
on relationship User.expenses - there are multiple foreign key paths linking the tables.
Specify the 'foreign_keys' argument, providing a list of those columns which should be counted as containing a
foreign key reference to the parent table.

Tags: fromimportidbasestringsqlalchemyaddresscolumn
1条回答
网友
1楼 · 发布于 2024-05-15 22:29:51

如果我使用“backref”而不是“back\u populates”,这是有效的。我将“backref”放在两个外键都存在的一侧的关系中,并删除了另一个表中的关系。你知道吗

相关问题 更多 >