使用QuerySet删除和查询数据表(二)

(三)匹配符的使用

1、匹配符表

在这里插入图片描述

2、案例演示

1、查询职业表里job包含“开发”的记录

  • 使用__contains匹配符来实现

在这里插入图片描述

  • 使用原生的SQL语句完成相同的任务
    在这里插入图片描述

2、查询职业表里薪资为8000、12000、20000的记录

  • 使用__in匹配符来实现

在这里插入图片描述

  • 使用原生的SQL语句完成相同的任务
    在这里插入图片描述

3、查询职业表里薪资在10000与20000之间的记录

  • 使用__range匹配符来实现

在这里插入图片描述

  • 使用原生的SQL语句来完成同样的任务
    在这里插入图片描述

(四)查询多表数据

  • index_vocation表
    在这里插入图片描述
  • index_personinfo表
    在这里插入图片描述

1、正向查询:通过主表查子表

  • 查找职业表id=2的记录的人员信息

在这里插入图片描述

  • 查找薪资在10000及以上的人员信息
    在这里插入图片描述

2、反向查询:通过子表查主表

  • 查询人员信息表中id=2的职业信息
    在这里插入图片描述
    在定义Vocation模型时设置了related_name=‘ps’,在反查时只能通过“ps”去找对象PersonInfo,否则可以使用以下方式:
v = p.vocation_set.first()
print(p.name, v.job, v.title, v.payment)

(五)使用select_related()实现关联查询

1、利用PersonInfo关联查询Vocation

  • 查询人员姓名及薪资(姓名来自PersonInfo对象,薪资来自Vocation对象),对应逆向查询
    在这里插入图片描述
  • 不妨查看一下框架帮我们生成的关联查询语句
    在这里插入图片描述
  • 到Navicat里去运行上面的查询语句(采用的是左外连接)
    在这里插入图片描述

2、利用Vocation关联查询PersonInfo

查询薪资在12000及以上的职业、姓名、年龄与薪资

  • 方法一、利用Vocation关联查询PersonInfo (正向关联查询)—— 外键

在这里插入图片描述
在这里插入图片描述

  • 方法二、利用PersonInfo关联查询Vocation(逆向关联查询)——关联名
    在这里插入图片描述
    在这里插入图片描述
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值