繁体   English   中英

SQLAlchemy map 列出相关对象

[英]SQLAlchemy map to list related objects

我在 SQLAlchemy 中的两个实体之间的映射关系有问题。 我正在尝试实现下一个行为-> map 向用户提供所有相关反馈。 该关系是另一边的receiver_id ,它等于user_id 因此,用户 1 正在为用户 2 发送反馈,当我得到用户 2 object 时,我正试图将它们作为列表获取。 我有下一个代码

class User(Base):
    __tablename__ = "user"
    user_id = sa.Column('user_id', UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
    first_name = sa.Column('first_name', sa.String)
    last_name = sa.Column('last_name', sa.String)
    phone_number = sa.Column('phone_number', sa.String(20), unique=True)
    email = sa.Column('email', sa.String, unique=True)
    is_active = sa.Column('is_active', sa.Boolean, server_default=expression.true(), nullable=False)
    deleted = sa.Column('deleted', sa.Boolean, server_default=expression.false(), nullable=False)
    created_time = sa.Column('created_time', sa.DateTime, server_default=func.now(), nullable=False)
    updated_time = sa.Column('updated_time', sa.DateTime, server_default=func.now(), nullable=False)
    deleted_time = sa.Column('deleted_time', sa.DateTime)
    feedbacks = relationship('UserFeedback', primaryjoin='User.user_id == UserFeedback.receiver_id', uselist=True, lazy='dynamic', backref='user_feedback')


class UserFeedback(Base):
    __tablename__ = "user_feedback"
    id = sa.Column('id', sa.Integer, primary_key=True, autoincrement=True)
    sender_id = sa.Column(UUID(as_uuid=True), ForeignKey("user.user_id"), nullable=False)
    receiver_id = sa.Column(UUID(as_uuid=True), ForeignKey("user.user_id"), nullable=False)

    sender = relationship("User", foreign_keys=[sender_id])
    receiver = relationship("User", foreign_keys=[receiver_id])

    rating = sa.Column('rating', sa.DECIMAL, nullable=False)
    feedback = sa.Column('feedback', sa.String, nullable=False)
    date = sa.Column('date', sa.DateTime, server_default=func.now(), nullable=False)

我已经用用户反馈填充了数据库,但是当我拉用户 ORM 时,没有 map 相关的反馈。 它实际上甚至没有这个字段,所以这有点令人困惑

我正在学习 SQLAlchemy,因此非常感谢您的帮助或建议

问题是您正在对关系使用dynamic加载策略( 文档在此处)。

使用lazy = 'dynamic'查询时,SQLAlchemy 会生成单独的查询,而不是获取实际结果。 因此,在您最初的情况下, feedbacks属性包含另一个select语句( AppenderQuery类型),您可以手动执行。

要简单地获取相关数据,只需将“动态”更改为“已加入”。

您可以在文档这篇漂亮的帖子中阅读有关关系加载策略的更多信息。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM