基于双下划线查询

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

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. IntelliJ idea -- 在WEB-INF下创建两个文件夹:classes 和 lib

    1.首先在WEB-INF下面创建两个文件夹 classes  和 lib 2.文件 --> 项目结构 3.选择路径 4.选择依赖项 5.选择刚创建好的lib文件夹,然后确定 6.选择 Jar D ...

  2. ESP32引脚参考(转)

    ES​P32芯片配有48个具有多种功能的引脚.并非所有的引脚都暴露在所有的ESP32开发板中,有些引脚不能使用. 关于如何使用ESP32 GPIO有很多问题.你应该用什么pin?在项目中应该避免使用哪 ...

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

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

  4. 高校表白App-团队冲刺第六天

    今天要做什么 在引导页的基础上添加小红点,并且在滑动时进行增强用户体验的修饰 做了什么 在布局中成功添加小红点,并在activity中得到实现;滑动在3/4时发生渐变,增强用户体验;滑动可回退;在最后 ...

  5. Scala学习——模式匹配

    scala模式匹配 1.基础match case(类似java里switch case,但功能强大些) object MatchApp { def main(args: Array[String]): ...

  6. C#中使用jieba.NET、WordCloudSharp制作词云图

    目录 词云简介 准备工作 基本算法 算法实现 运行测试 参考资料 词云简介 "词云"由美国西北大学新闻学副教授.新媒体专业主任里奇·戈登(Rich Gordon)于2006年最先使 ...

  7. ESLint自用规则

    官方文档地址 rules: { // allow async-await 'generator-star-spacing': 'off', // allow debugger during devel ...

  8. Echarts的应用实践

    Echarts官网:https://echarts.apache.org/ echarts是百度推出的,使用JavaScript实现的开源可视化库,可以提供直观.可定制化的数据可视化图表,包括折线图. ...

  9. Python基础之控制台打印不同颜色字符串

    参考文章:https://www.cnblogs.com/daofaziran/p/9015284.html 打印各种颜色的文字,但是需要传入文字 print_color.py "" ...

  10. g6中的变换矩阵matrix

    在看g6文档的时候看到一个变换矩阵,不明觉厉,如下 matrix = 1 0 0 0 1 0 0 0 1 于是查资料了解里面每个数字的意义,和css3的matrix()方法似乎类同 transform ...