flask学习之数据表对应关系:一对多

表对应关系存在三种 一对一 一对多 多对多
一对多:假设要添加一个功能,保存用户的邮箱账号,并且邮箱账号有多个,这时候就必须创建一个新的表,用于存储用户的邮箱,通过user.id来作为外键进行引用
在本例子中,使用的是一个作者与文章的实例,一个作者可以有多篇文章,这就是个一对多,但是每篇文章对应的是一个作者。

  • 在这里要从一篇文章找文章的作者,找到的是一个确定的值,如果从一个作者找到其文章,找到的是一个可迭代对象,因为是存在一对多,查到的是1个可迭代的。
    实现方式:
    1.引入relationship
from sqlchemy.orm import relationship

2.在两个表之中定义relationship

class User(Base):
    __tablename__ = 'user'

    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String(50))

    # 添加反向查询的属性
    # article = relationship('Article', backref='article')
    article = relationship('Article')

    def __str__(self):
        return 'User(name:{})'.format(self.name)


class Article(Base):
    __tablename__ = 'article'

    id = Column(Integer, primary_key=True, autoincrement=True)
    title = Column(String(50))
    content = Column(TEXT, nullable=False)
    uid = Column(Integer, ForeignKey('user.id', ondelete='RESTRICT'))

    author = relationship('User')

    def __str__(self):
        return 'Article(title:{})'.format(self.title)

注:含有外键定义的属于多,
这个查询是建立在外键的基础上的,如果不添加外键,是不能实现这里的一对多的。

sqlalchemy.exc.NoForeignKeysError: Could not determine join condition between parent/child tables on relationship User.article - there are no foreign keys linking these tables.  Ensure that referencing columns are associated with a ForeignKey or ForeignKeyConstraint, or specify a 'primaryjoin' expression.

如果将外键去除,则需要添加反向查询的属性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值