django之多表查询-2
2018-11-14
一 \\ 基于双下划线的跨表查询:
套路一样,用__跨表
-一对多
-多对多 from app.models import * 查询出版社为北京出版社出版的所有图书的名字,价格
ret=Publish.objects.filter(name='北京出版社').values('book__name','book__price') 查询红楼梦的所有作者名字
ret=Book.objects.filter(name='红楼梦').values('authors__name') 进阶练习--连续跨表
查询北京出版社出版过的所有书籍的名字以及作者的姓名
ret=Publish.objects.filter(name='北京出版社').values('book__name','book__authors__name') 二 \\ 聚合查询
from django.db.models import Avg,Count,Max,Min,Sum
1.计算所有图书的平均价格
ret = Book.objects.all().aggregate(Avg('price')) #可以省略all()
print(ret)
2. 计算图书的最高价格
ret = Book.objects.aggregate(Max('price'))
print(ret)
3. 计算图书的最高价格,最低价格,平均价格,总价
ret = Book.objects.aggregate(Max('price'),Min('price'),Avg('price'),Sum('price'))
print(ret)
三 \\ 分组查询
终极总结:
values在前,表示group by,在后,表示取值
filter在前,表示过滤(where),在后,表示having(对分组之后的结果再进行过滤)
1.统计每一本书作者个数
ret = Book.objects.annotate(c=Count('authors')).values('name','c')
print(ret) 2.统计每一个出版社的最便宜的书(以谁group by 就以谁为基表)
ret = Publish.objects.annotate(m=Min('book__price')).values('name','m')
print(ret) 3.统计每一本以py开头的书籍的作者个数
ret = Book.objects.filter(name__startswith='py').annotate(m=Count('authors')).values('name','m')
print(ret) 4.查询各个作者出的书的总价格
ret = Author.objects.annotate(m=Sum('book__price')).values('name','m')
print(ret) 5.查询名字叫lqz作者书的总价格
ret = Author.objects.filter(name='lqz').annotate(m=Sum('book__price')).values('name','m')
print(ret) 6.查询所有作者写的书的总价格大于30
ret = Book.objects.annotate(s=Sum('authors__book__price')).filter(s__gt=900).values('authors__name','s')
print(ret)
四 \\ F查询与Q查询
F查询
1.查询评论数大于阅读数的书
ret = Book.objects.filter(commit_num__gt=F('read_num'))
print(ret) 2.把所有书的评论数加1
ret = Book.objects.update(commit_num=F('commit_num') + 1) 3.把python这本书的阅读数减5
ret = Book.objects.update(read_num=F('read_num')-5) Q函数 为了表示与& ,或 | ,非 ~
# 1.查询作者名字是lqz或者名字是egon的书
ret = Book.objects.all().filter(Q(authors__name='zjh') | Q(authors__name='egon')).values('name')
print(ret) # 2.查询作者不是zjh的书
ret = Book.objects.all().filter(~Q(authors__name='zjh')).values('name')
print(ret)
ret = Publish.objects.filter(name='北京出版社').values('name','book__name','book__authors__name')
django之多表查询-2的更多相关文章
- Django 之多表查询 与多表的使用
1.django的多表查询 主要区分为: 正向查询 逆向查询 1. 多表查询: 是一个复杂的查询,他分为对象查询和__模糊查询两种方式 2. 多表查询: 又分为 一对一查询, 一对多查询, 多对 ...
- Django开发之路 二(django的models表查询)
django的models表查询 一.单表查询 (1) all(): 查询所有结果 # 返回的QuerySet类型 (2) filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 #返 ...
- 第五章、Django之多表查询进阶与事务
目录 第五章.Django之多表查询 一.聚合查询 二.分组查询 三.F与Q查询 四.查询优化 五.Django开启事务 六.自定义char字段 七.ORM常用字段 第五章.Django之多表查询 一 ...
- django之跨表查询及添加记录
一:创建表 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-many); 一本书只应该由一个出版商出 ...
- Django框架----跨表查询及添加记录
一:创建表 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-many); 一本书只应该由一个出版商出 ...
- django之多表查询与创建
https://www.cnblogs.com/liuqingzheng/articles/9499252.html # 一对多新增数据 添加一本北京出版社出版的书 第一种方式 ret=Book.ob ...
- django之多表查询
一.创建模型 在Models创建如下模型: from django.db import models # Create your models here. # 用了OneToOneField和Fore ...
- Django模板及表查询笔记
模板层 后端朝html页面传递数据 两种给html页面传递数据的方式 第一种: render(request,'index.html',{'user_list':user_list}) 第二种 ren ...
- Django ORM多表查询练习
ORM多表查询 创建表结构: from django.db import models # 创建表结构 # Create your models here. class Class_grade(mod ...
随机推荐
- java中的Closeable接口
一.概述 该接口位于java.io包下,声明例如以下:public interface Closeable Closeable 是能够关闭的数据源或目标. 调用 close 方法可释放对象保存的资源( ...
- KVC之-(id)valueForKey:(NSString *)key的实现原理与验证
KVC之-(id)valueForKey:(NSString *)key的实现原理与验证 2.-(id)valueForKey:(NSString *)key的实现原理与验证; #功能:使用一个字符串 ...
- cp/scp命令详解
cp:拷贝命令 用法: cp [参数] source dest cp [参数] source ... directory 说明:将一个档案拷贝至另一个档案,或数个档案拷贝到另一目录 参数: -a 尽可 ...
- 消除^M
在Linux和windows之间移动文件时,总是会出现在windows下编辑的文件在Linux打开时每一行都显示一个^M,虽然不影响使用,但是却影响美观,于是就想自己实现个小程序来进行转换. 要实现转 ...
- Easyui data方法扩展finder
finder: function(jq, conditions){ if(!$(jq).data("OriginalData")){ $(jq).data("Origin ...
- Linux设备驱动程序学习之分配内存
内核为设备驱动提供了一个统一的内存管理接口,所以模块无需涉及分段和分页等问题. 我已经在第一个scull模块中使用了 kmalloc 和 kfree 来分配和释放内存空间. kmalloc 函数内幕 ...
- HP proliant服务器从usb启动
1,开机出现自检画面开始按F9进入设置,进入BIOS 选择standard boot order(rpl),把usb driver放在第一位,保存好 2,按F1开始启动. (注:我使用ubuntu14 ...
- iOS --转载 NSRange 和 NSString 详解
一.NSRange 1.NSRange的介绍 NSRange是Foundation框架中比较常用的结构体, 它的定义如下: typedef struct _NSRange { NSUInteger l ...
- PatternSyntaxException:Syntax error in regexp pattern
Caused by: java.util.regex.PatternSyntaxException: Syntax error in regexp pattern near index 1: ...
- IOS开发之 -- 线程初识
对于开发者来说,多线程永远有这一层神秘的色彩,似乎是一到迈步过去的坎,在同步.异步.串行.并行.死锁这几个名字当中,逐渐的放弃治疗,下面就多线程,谈一下自己的认识,理解的肯定不全面,只是一些简单的皮毛 ...