20181014:学习认识flask_sqlalchemy中定义字段中foreignkey 和 relationship之间的关系和调用原理

先看下面的代码说明,这种代码一般放在models.py里,实际就是定义数据库中表的结构
在这里插入图片描述
假设有管理员和角色两个类,一个角色(一A)可以对应多个管理员(多B),形成1对多。
一A 对 多B:A中使用relationship,B中使用ForeignKey,我们总是在“多B”中设置某个字段使用Foreignkey来对应“一A”中的唯一ID。(1A中设置relationship但多B中未设置ForeignKey,系统将报错)
总结就是:
1、首先在“多B-管理员”设置个字段用foreignkey对应到“1A-角色”中的唯一主键ID,这样就建立了一对多关系。
在这里插入图片描述
2、然后,就可以在“1A-角色”中设置relationship来对应到“多B”了。
在这里插入图片描述
3、好了,这样查询到某个或某些角色信息的时候,就可以同时通过(role.admins)非常简单的获得该角色对应到的所有管理员信息了。one role → lot admin(role.admins)
通过角色获取对应了所有管理员信息后,如果又还要反查管理员对应的角色信息,则在relationship中多加个参数“backref”即可做到反查。one admin → admin.role (注意此处的role是在backref中定义的那个,而不是只class Role)。当然, 查询到某个或某些管理员信息后,直接通过role反查也没问题。
在这里插入图片描述
4、其实ForeignKey的作用就基本是SQL原生语句中的left jion 的作用。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值