基于双下划线查询

根据存的时候,字段的数据格式衍生的查询方法

1、年龄大于35岁

res = models.AuthorDetails.objects.filter(age__lt=80)
print(res) # 输出结果 <QuerySet [<AuthorDetails: yuhua@dd>, <AuthorDetails: cao@di.com>, <AuthorDetails: gao@doi.com>]>

2、年龄小于35岁

res = models.AuthorDetails.objects.filter(age__gt=80)
print(res) # 输出结果 <QuerySet [<AuthorDetails: jinyong@qr.com>]> # 大于等于 小于等于
# res = models.User.objects.filter(age__gte=32)
# print(res)
# res = models.User.objects.filter(age__lte=32)
# print(res)

3、年龄等于48或者32

res = models.AuthorDetails.objects.filter(age__in=[48, 32])  # 表示or关系 列表括起来
print(res) # 输出结果 <QuerySet [<AuthorDetails: cao@di.com>, <AuthorDetails: gao@doi.com>]>

4、年龄在48或者56岁之间的

res = models.AuthorDetails.objects.filter(age__range=[32, 56])  # 这里的range是包括头和尾的
print(res) <QuerySet [<AuthorDetails: yuhua@dd>, <AuthorDetails: cao@di.com>, <AuthorDetails: gao@doi.com>]>

5、查询名字里面含有g的数据 模糊查询

# where name like '%i%'
res = models.Author.objects.filter(name__contains='i')
# 对应SQL语句 'contains': 'LIKE BINARY %i%' 其中的BINARY是精确大小写 res = models.Author.objects.filter(name__icontains='I')
# 'icontains': 'LIKE %s' 而’icontains’中的’i’表示忽略大小写

6、以查询名字以g结尾的

res = models.Author.objects.filter(name__endswith='g')
# 以g结尾的 res = models.Author.objects.filter(name__startswith='y')
# 以y开头的

7、导出9月份数据(重要)

res = models.User.objects.filter(create_time__month='04')
print(res) # 这里需要注意的是时间字段不能设为DateTimeFiled否则是查不出来的 # 查询一年中某个月的数据
res = models.User.object.filter(create_time_month='04', create_time_year='2021')

一对多的增删改查

# 这里增加还是需要先建关联的那一张表
models.Book.objects.create(title='许三观卖血记', price=32.98, publish_id=2) models.Book.objects.filter(pk=4).update(price=33.45) # 删除的话会级联更新,级联删除。 book_obj = models.Book.objects.filter(pk=1).first()
print(book_obj.publish) # 正向查询

多对多的增删改查

1.book_obj = models.Book.objects.filter(pk=3).first()
book_obj.author.add(3, 5)
# .author跳转到第三张表 2. author_obj = models.Author.objects.filter(pk=1).first()
book_obj = models.Book.objects.filter(pk=1).first()
book_obj.authors.add(author_obj)

book_obj = models.Book.objects.filter(pk=3).first()
book_obj.author.set([3, 5]) # 这里的set方法要放列表,可迭代对象

book_obj = models.Book.objects.filter(pk=3).first()
book_obj.author.remove(3,3)
# 书id=3对应着的作者id=3的删除 clear可以清空数据

book_obj = models.Book.object.filter(pk=3).first()
print(book_obj.author.all()) # 当查询结果为多个的时候,要加.all()
# 当查询结果为一个的时候,不要加.all()
正反向的概念,为了更好的记忆
# 正向:比如外键字段在A表中,需要通过A表去查B表,那这个查询方向就是正向的
# 反向:比如外键字段在A表中,需要通过B表去查A表,那这个查询方向就是反向的 正向查询按字段查
反向查询按表名小写,或者表明小写_set.all()(有多个结果时)

聚合查询

使用聚合查询需要导入模块

from django.db.models import Max, Min, Sum, Count, Avg

聚合查询有一个关键字aggregate:

.aggregate(聚合函数名('字段名'))
 1 所有书的平均价格 select avg(price) from book where id > 2
res = models.Book.objects.aggregate(Avg('price')) """
聚合查询需要加aggregate
分组查询需要加annotate
"""
print(res) res = models.Book.objects.aggregate(avg=Avg('price'), price_max=Max('price'), price_min=Min('price'), sum=Sum('price'), count=Count('price'))
print(res)

分组查询

关键字annotate

# 1.统计每一本书的作者个数
res = models.Book.objects.annotate() # 默认就是按照models后面的表名分组
print(res) res = models.Book.objects.annotate(count=Count('authors__pk')).values("title", 'count')
print(res) # 2.统计每个出版社卖的最便宜的书的价格
res = models.Publish.objects.annotate(price_min=Min('book__price')).values('title', 'price_min')
# .values是为了更好的查看,返回一个可迭代的字典序列
print(res) # <QuerySet [{'title': '雪山飞狐打折', 'price': Decimal('34.22'), 'publish': 3}]> # 3.统计不止一个作者的图书
# 1) 先查询每一本书的作者个数,
# 2) 在筛选出大于1的 res = models.Book.objects.annotate(author_num=Count('authors__pk')).filter(author_num__gt=1).values('title', 'author_num')
print(res) """
res = models.Book.objects.values('').annotate
"""

Django ORM多表查询的更多相关文章

  1. Django ORM多表查询练习

    ORM多表查询 创建表结构: from django.db import models # 创建表结构 # Create your models here. class Class_grade(mod ...

  2. django ORM 连表查询2

    set() 更新model对象的关联对象 book_obj=models.Book.objects.first() book_obj.authors.set([2,3]) 把book_obj这个对象重 ...

  3. django ORM 连表查询

    db_index=True  如果设置该字段就可以设置索引 auto_now_add  代表设置创建时候的时间 auto_now   每次更新数据记录时会更新该字段 to_field 设置要关联表的字 ...

  4. Django ORM单表查询必会13条

    必知必会13条 操作下面的操作之前,我们实现创建好了数据表,这里主要演示下面的操作,不再细讲创建准备过程 <1> all(): 查询所有结果 <2> filter(**kwar ...

  5. django orm跨表查询废话最少最精简版

    在model.py中: class B1(models.Model): u1= models.CharField(max_length=32) #多 class B2(models.Model): f ...

  6. python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

    12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefaul ...

  7. 第五章、Django之多表查询进阶与事务

    目录 第五章.Django之多表查询 一.聚合查询 二.分组查询 三.F与Q查询 四.查询优化 五.Django开启事务 六.自定义char字段 七.ORM常用字段 第五章.Django之多表查询 一 ...

  8. 第十七篇 ORM跨表查询和分组查询---二次剖析

    ORM跨表查询和分组查询---二次剖析 阅读目录(Content) 创建表(建立模型) 基于对象的跨表查询 一对多查询(Publish与Book) 多对多查询 (Author 与 Book) 一对一查 ...

  9. ORM单表查询,跨表查询,分组查询

    ORM单表查询,跨表查询,分组查询   单表查询之下划线 models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值models ...

随机推荐

  1. Linux学习之路(RPM和YUM)

    rpm包的管理 介绍: 一种用于互联网下载包的打包及安装工具(类似windows中的setup).它包含在某些Linux分发版中.它生成具有RPM扩展名的文件.RPM是RedHat软件包管理工具缩写, ...

  2. Leetcode No.122 Best Time to Buy and Sell Stock II Easy(c++实现)

    1. 题目 1.1 英文题目 You are given an array prices where prices[i] is the price of a given stock on the it ...

  3. C#下通过wbemtest和WMI Code Cretor更加高效的访问WMI

    能找到这篇博客的,相信都是有操作WMI需求的了.但是不知道如何快速验证.并集成到C#来操作WMI.我们分为3步: ##第一步:官网(或跟硬件开发WMI的人沟通你需要的接口和参数定义,如果是和硬件开发的 ...

  4. iPhone X适配方案

    iPhone X适配方案 https://github.com/Wscats/iPhone-X 绝对长度单位 英寸 厘米 毫米 磅 pc inch cm mm pt pica 相对长度单位 是网页设计 ...

  5. Tuleap administration 管理员页面中项目的配置页面

    1) 进入Administration界面,点击[Browse All] 2) 所有的项目会在项目页面中展示出来 3)在Details后面点击按钮,选择 [go to project administ ...

  6. EditPlus运行java时如何从键盘输入数据

    在练习Java的Scanner时,EditPlus如何读取从键盘输入的数呢? 例如如下程序,编译通过,运行时却输入不了数据: 1 package myP101; 2 3 import java.uti ...

  7. 【LeetCode】12. 整数转罗马数字

    12. 整数转罗马数字 知识点:字符串 题目描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 100 ...

  8. python之数据驱动Excel操作(方法一)

    一.Mail163.xlsx数据如下: 二.Mail163.py脚本如下 import xlrdimport unittestfrom selenium import webdriverfrom se ...

  9. Selnium + POM + Pytest:学习记录

    简介 selenium POM Pytest 结合,通过Pytest fixture 来传递Driver 保证一个测试用例[1] :driver[1] 学习记录 插件包 selenium: 操作浏览器 ...

  10. 谷粒学院-2-mybatisplus

    一.参考文档 官网:http://mp.baomidou.com/ 参考教程:http://mp.baomidou.com/guide/ MyBatis-Plus(简称 MP)是一个 MyBatis ...