[英]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,因此非常感谢您的帮助或建议
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.