day73
1基于双下划线的跨表查询
套路一样,用__跨表
-一对多
# 北京出版社出版的所有图书
res = models.Publish.objects.filter(name='北京出版社').values('book__name')
print(res)
# 三国演义的所有作者
res = models.Book.objects.filter(name='三国演义').values('authors__name')
print(res)
# 跨表改
# 将lay出版的所有书的出版社的邮箱改为987@qq.com
# models.Publish.objects.filter(book__authors__name='lay').update(email='987@qq.com')
-聚合函数
from django.db.models import Avg,Count,Max,Min,Sum
# 计算所有图书的平均价格
from django.db.models import Max,Min,Count,Sum,Avg
# 所有图书的总价
res = models.Book.objects.all().aggregate(s=Sum('price'))
print(res)
# 红楼梦的有多少个作者
res = models.Book.objects.filter(name='红楼梦').aggregate(c=Count('authors'))
print(res)
# 郑棒写的最贵的书
res = models.Author.objects.filter(name='郑棒').aggregate(m=Max('book__price'))
print(res)
# 郑棒出版社出版的最便宜的价格
res = models.Publish.objects.filter(name='郑棒出版社').aggregate(m=Min('book__price'))
print(res)
3分组查询
# 分组查询
# 查询所有出版社的多少书
# res = models.Publish.objects.all().annotate(c=Count('book__name')).values('name','c')
# print(res)
# 统计每一本书作者个数
# res = models.Book.objects.all().annotate(c=Count('authors')).values('name', 'c')
# print(res)
# 统计每一个出版社的最便宜的书
# res = models.Publish.objects.annotate(m=Min('book__price')).values('name', 'm')
# print(res)
# 统计每一本以py开头的书籍的作者个数
# res = models.Book.objects.filter(name__startswith='py').annotate(c=Count('authors')).values('name', 'c')
# print(res)
# 查询各个作者出的书的总价格
# res = models.Author.objects.all().annotate(s=Sum('book__price')).values('name', 's')
# print(res)
终极总结:
values在前,表示group by,在后,表示取值
filter在前,表示过滤(where),在后,表示having(对分组之后的结果再进行过滤)
4 F查询与Q查询
from django.db.models import F, Q
# 查询阅读数大于评论数的图书
res = models.Book.objects.filter(read__gt=F('commit'))
print(res)
# 把所有书的评论数加1
res = models.Book.objects.update(commit=F('commit') + 1)
# 把python这本书的阅读数减5
res = models.Book.objects.filter(name__startswith='py').update(read=F('read') - 5)
# Q函数表示与&,或|,非~
# 查询作者名字不是郑棒或者名字不是徐都会的书
res = models.Book.objects.exclude(Q(authors__name='郑棒')|Q(authors__name='徐都会'))
print(res)
# 查询北京出版社出版的书籍的作者的电话号码,如果电话号码13开头的将作者地址改为北京
res = models.Author.objects.filter(Q(author_details__phone__startswith='13') & Q(book__publish__name='北京出版社')).update(addr='北京')
print(res)
5 常用字段:必须记住,非常用字段,了解即可
6 orm字段参数:
-null 可以为空
-unique 唯一性约束
-default 默认值
-db_index 为该字段建索引
-只给日期类型和时间类型用
-auto_now_add 新增数据时,默认把当前时间存入
-auto_now 修改的时候,默认把当前时间存入
7 关系字段
ForeignKey
-to 关联哪个表
-to_field 关联的字段
-related_name 反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'。(一般不要用)
-related_query_name :基于双下划线的反向查询之前按表名小写(一般不要用)
-on_delete:models.CASCADE,models.SET_NULL
-db_constraint:db_constraint=False代表,不做外键关联
day73的更多相关文章
- day73 Django框架之URL
Django框架之url路由层一 Django数据库的一对多与多对多表的建立 一对多 publish_id的建立:publish=models.ForeignKey(to='Publish', to ...
- day73 中间件 以及模板引擎
模板引擎: 基本实用{{k1}} if for 模板中自定义函数:操作步骤 1在已经注册的App中创建一个名字叫templates文件夹 2任意创建一个py文件, 3创建名字叫register 的L ...
- python 全栈开发,Day73(django多表添加,基于对象的跨表查询)
昨日内容回顾 多表方案: 如何确定表关系呢? 表关系是在2张表之间建立的,没有超过2个表的情况. 那么相互之间有2条关系线,先来判断一对多的关系. 如果其中一张表的记录能够对应另外一张表的多条记录,那 ...
- day73 母版 中间件
关于母版自定义的问题 模板引擎: 基本实用{{k1}} if for 在页面传参数 并判断 通过母版进行交互 一 模板中自定义函数:操作步骤 1在已经注册的App中创建一个名字叫templat ...
- day73 bbs项目☞基本功能实现
目录 一.登录功能 二.首页搭建 三.admin后台管理 四.图片防盗链 五.个人站点展示 一.登录功能 views.py 0难度,都是基本操作,要熟悉auth模块的使用 # 登录功能 def log ...
- day73:drf:drf视图相关类&路由Routers&创建虚拟环境
目录 1.APIView 2.GenericAPIView:通用视图类 3.5个视图扩展类:ListModelMixin,CreateModelMixin,RetrieveModelMixin,Upd ...
- C++windows内核编程笔记day09_day10,对话框和窗体基本控件等的使用
//设置字体颜色 SetTextColor(hdc,RGB(255,0,0)); //窗体背景 //wce.hbrBackground=(HBRUSH)(COLOR_WINDOW+1); //wce. ...
- python CSRF跨站请求伪造
python CSRF跨站请求伪造 <!DOCTYPE html> <html lang="en"> <head> <meta chars ...
- 100 天从 Python 新手到大师
Python应用领域和就业形势分析 简单的说,Python是一个“优雅”.“明确”.“简单”的编程语言. 学习曲线低,非专业人士也能上手 开源系统,拥有强大的生态圈 解释型语言,完美的平台可移植性 支 ...
随机推荐
- influxdb-1.7.2.x86_64安装 install influxdb-1.7.2.x86_64 on RedHat & CentOS
1.下载安装 wget http://dl.influxdata.com/influxdb/releases/influxdb-1.7.2.x86_64.rpm https://portal.infl ...
- js-ES6学习笔记-Iterator
1.遍历器(Iterator)是一种接口,为各种不同的数据结构提供统一的访问机制.任何数据结构只要部署Iterator接口,就可以完成遍历操作(即依次处理该数据结构的所有成员). 2.Iterator ...
- for循环中嵌套setTimeout,执行顺序和结果该如何理解?
这两天在捣鼓作用域的问题,有的时候知识这个东西真的有点像是牵一发而动全身的感觉.在理解作用域的时候,又看到了一道经典的面试题和例子题. 那就是在for循环中嵌套setTimeout延时,想想之前面试的 ...
- 前端开发笔记(1)html基础
HTML介绍 HTML是HyperTextMarkupLanguage超文本标记语言的缩写 HTML是标记语意的语言 编辑器 任何纯文本编辑器都能够编辑html,比如记事本,editplus,note ...
- 使用ArcGIS Runtime 100 进行本地GIS数据处理的注意事项
如下图所示,如果需要使用ArcGIS Runtime 100 进行本地GIS数据处理,则需要依赖Local Server通过发布GP服务实现. 一.ArcGIS Runtime所使用的GPK是有版本限 ...
- as 打包报错
错误:Android Error:Execution failed for task ':app:transformClassesAndResourcesWithProguardForRelease' ...
- AutoCompleteTextView 自定义提示样式
项目中用到AutoCompleteTextView 自动提示功能,如果用自带的ArrayAdapter就一种样式,非常丑,而且每一项提示文字过多的话不会自动换行. 所以自己自定义了一个适配器. 效果 ...
- 解决 jQuery validation插件 valid()方法总是返回true的问题
在表单元素验证方法中加入了 remote 方法,调试一直返回true,后来才知道因为是异步验证,所以才会出现此问题,解决方法就是在 remote 方法中,禁用 异步和缓存,具体代码如下 : ..... ...
- LeeTCode题解之Remove Duplicates from Sorted List
1.题目描述 2.问题分析 对于链表中的每一个元素,找到其后面和它不相等的第一个元素,然后指向该元素. 3.代码 ListNode* deleteDuplicates(ListNode* head) ...
- mysql 表格操作指令大全(Show、desc、create、insert into、delete、select、drop、update、alter)
使用数据库 use 数据库名 eg: use weiying 2. 查看库里所有的表 Show tables 3.查看所表的结构 desc 表名 desc score 4.建表create tabl ...