当前位置: 首页 > 面试题库 >

sqlalchemy外键关系属性

赵雅懿
2023-03-14
问题内容

我有一个用户表和一个朋友表。朋友表拥有两个外键,分别指向我的用户表和状态字段。我试图能够从Friend对象上的User表中调用属性。例如,我希望能够执行诸如friend.name或friend.email之类的操作。

class User(Base):
    """ Holds user info """

    __tablename__ = 'user'
    id = Column(Integer, primary_key=True)
    name = Column(String(25), unique=True)
    email = Column(String(50), unique=True)
    password = Column(String(25))
    admin = Column(Boolean)

    # relationships
    friends = relationship('Friend', backref='Friend.friend_id',primaryjoin='User.id==Friend.user_id', lazy='dynamic')

class Friend(Base):
    __tablename__ = 'friend'

    user_id = Column(Integer, ForeignKey(User.id), primary_key=True)
    friend_id = Column(Integer, ForeignKey(User.id), primary_key=True)
    request_status = Column(Boolean)

当我得到friend对象时,我所拥有的只是2,user_ids并且我想显示每个用户的所有属性,以便可以在表单等中使用该信息。我对sqlalchemy还是陌生的-
仍在尝试学习更高级的功能。这只是一个更大的Flask项目的一个片段,此功能将用于friend请求等。我试图查找关联对象等,但是我很难解决。

任何帮助将不胜感激。


问题答案:

首先,如果使用flask-sqlalchemy,为什么直接使用sqlalchemy而不是Flask的db.Model

我强烈建议使用flask-sqlalchemy扩展,因为它利用了会话和其他一些巧妙的东西。

创建代理便捷对象很简单。只需在Friend类中添加关系即可。

class Friend(Base):
    __tablename__ = 'friend'

    user_id = Column(Integer, ForeignKey(User.id), primary_key=True)
    friend_id = Column(Integer, ForeignKey(User.id), primary_key=True)
    request_status = Column(Boolean)

    user = relationship('User', foreign_keys='Friend.user_id')
    friend = relationship('User', foreign_keys='Friend.friend_id')

SQLAlchemy将负责其余的工作,您可以通过以下方式简单地访问用户对象:

name = friend.user.name

如果您计划user每次使用该friend对象lazy='joined',请在中指定
relationship。这样,它将在单个查询中加载两个对象。



 类似资料:
  • 问题内容: 我在SQLAlchemy上没有太多经验,并且有一个我无法解决的问题。我尝试搜索,并且尝试了很多代码。这是我的课程(简化为最重要的代码): 我想查询所有母亲的phenoscore为(例如)的患者 如前所述,我尝试了很多代码,但我不明白。在我看来,合乎逻辑的解决方案是 因为,您可以在输出时访问每个元素,但是此代码不执行此操作。 是否有(直接)按关系的属性进行过滤的可能性(无需编写SQL语句

  • 我有一个奇怪的问题。 我有一个用户表和一个公司表。一个用户属于一家公司,而一家公司有许多用户。 表的两个主键都是id。 在laravel文档中,我阅读了以下内容: 此外,Eloquent假设外键的值应该与父项的id列匹配。 我在我的

  • null null 表名: ISBN->外键 authorid->外键 既然Linq-to-SQL会根据外键关系自动创建属性,为什么下面的代码块不会触发智能感知呢?对我来说不是... 它不允许我添加照片,但“author”与AuthorISBN有“一对多”关系,“titles”也与AuthorISBN有“一对多”关系 代码:

  • 问题内容: 由于已经暗示了该关系,因此我不想在db中创建约束。我该怎么办? 目前,我在进行Alembic迁移后手动删除这些约束。 问题答案: 无需定义“模式”级别约束,而是创建自定义的外部条件;将您要用作“外键”的列以及传递给。您必须手动定义原因,因为: 默认情况下,此值是基于父表和子表(或关联表)的外键关系计算的。 外键也可以在using中内联注释: 您可以验证没有为表 c 发出约束: 警告:

  • 问题内容: 我有一个简单的Author-Books模型,找不到将firstName和lastName用作复合键并在关系中使用它的方法。有任何想法吗? 问题答案: 问题在于您已将每个相关列分别定义为外键,如果这不是您想要的,那么您当然需要一个复合外键。Sqlalchemy通过说(以一种不太清楚的方式)对此做出响应,即无法猜测要使用哪个外键(或)。 声明复合外键的解决方案在声明性上有点笨拙,但仍然很明

  • 问题内容: 我知道你会说这个问题被问过很多次了,但是我还没有解决呢… models.py views.py 模板: 我已经尝试过上面的模板,但没有得到任何结果。所以我想在DocImage类中获取imageurl地址… 所有帮助 问题答案: 如果您查看外键文档,如果您有类似的关系 您需要像这样在DocImages类上定义外键: 如果您未设置相关名称,则可以像下面这样从Doc访问DocImage: 有