【Flask数据库】ORM层外键访问方式和一对多

文章目录

一对多外键关系

通过sqlalchemy.orm下的relationship实现
如一个作者可以有多篇文章,此为一对多关系。以下为通过文章找作者和通过作者找文章的例子:

from sqlalchemy.orm import relationship
class User(Base):
    ...
    username = Column(...)
    articles = relationship("article")

class Article(Base):
    ...
    author = relationship("User")
#用relationship,通过article表数据取user表对应id的数据
article = session.query(Article).first()
print(article.author.username)
#用relationship,通过user表数据取article表对应id的数据
user = session.query(User).first()
print(user.articles)

反向引用可使relationship成双向关系,使用反向引用则不需要在每个类后面设定relationship。

from sqlalchemy.orm import relationship
class User(Base):
    ...
    username = Column(...)

class Article(Base):
    ...
    author = relationship("User",beckref = "articles")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值