我在SQLAlchemy中两个实体之间的映射关系有一个问题。我正在努力实现下一个行为->映射到用户所有相关的反馈。另一边的关系是receiver_id
,它等于user_id
。所以,用户1发送一个反馈用户2,我试图让他们当我得到用户列表2对象。我有下一个代码
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不映射相关的反馈。它实际上甚至没有这个字段,所以这有点令人困惑
我正在学习SQLAlchemy,所以希望得到帮助或推荐
事情是你正在使用dynamic
加载策略的关系(文档在这里)。
当使用lazy = 'dynamic'
查询时,SQLAlchemy生成一个单独的查询,而不是获取实际结果。因此,在初始情况下,feedbacks
属性包含另一个select
语句(AppenderQuery
类型),您可以手动执行。
要获取相关数据,只需将'dynamic'更改为'joined'。
你可以在文档或这篇漂亮的文章中阅读更多关于关系加载策略的内容。