Django08-1:模型层(ORM)--聚合查询/分组查询/F与Q查询/开启事务/常用字段及参数/自定义字段/数据库查询优化

聚合查询

单独使用时,用aggregate

1.只要是跟数据库相关的模块

      基本都在django.db.models里面

       如果没有应该在django.db里面

2. 聚合查询通常配合分组使用


from django.db.models import Avg, Sum, Max, Min, Count# 1.所有书的平均价格
res=models.Book.objects.aggregate('price')ret = models.Book.objects.all().aggregate(price_avg=Avg("price"), price_max=Max("price"), price_min=Min("price"))

 

分组查询

annotate

models后面点什么,就是什么分组

# 1.查询每一本书的作者个数
ret = models.Book.objects.all().annotate(author_num=Count("author")).values('title','author_num')
print(ret)#author_num 自定义字段,用来统计每本书个数。#等价
ret = models.Book.objects.all().annotate(author_num=Count("author__pk")).values('title','author_num')
print(ret)

只要结果是queryset对象,就可以继续.filter()和.values()

#2.统计每个出版社的最便宜书的价格
res=models.Publish.objects.annote(min_price=Min('book__price')).values('name','min_price')#3. 统计不止一个作者的图书#a.先分组书籍,求每一步书籍的作者个数#b. 过滤不止一个作者的书籍
res=models.Book.objects.annote(author_num=Count('authors')).filter(author_num__gt=1).value('title','author_num')
#4. 查询每个作者出的书的总价格
res=models.Author.objects.annotate(sum_price=Sum('book__price')).values('name','sum_price')

扩展,其他分组方式

models.Book.values('price').annotate()

分组报错情况:去掉严格模式

 

F与Q查询

F功能:直接获取表中某个字段对应的数据

操作字符时,F不能直接做到字符拼接,

否则变成空白

# 1.查询卖出数大于库存书的书籍# F查询
from django.db.models import Fres=models.Book.objects.filter(maichu__gt=F('kuncun'))# 2.将所有书的价格提升50
models.Book.objects.update(price=F('price')+50)# 3.将所有书的名字后面加“爆款”两个字
#***操作字符时,F不能直接做到字符拼接
#***否则变成空白#需要导入两个模块
from django.db.models.functions import Concat
from django.db.models import Valuemodels.Book.objects.update(title=Concat(F('tittle'),Value('爆款')))

Q功能:能改变多个查询条件的关系,与或非

# Q 查询# 1.查询卖出数大于100 或者价格小于600的书籍res= models.Books.objects.filter(maichu__gt=100,price__lt=600)
#错误,filter内是and关系from django.db.models import Qres= models.Books.objects.filter(Q(maichu__gt=100),Q(price__lt=600)) #还是and关系res= models.Books.objects.filter(Q(maichu__gt=100)|Q(price__lt=600)) #Q可以用 |res= models.Books.objects.filter(~Q(maichu__gt=100)|Q(price__lt=600)) #前面取反# Q高阶用法 能够将查询条件左边变成字符串形式q=Q()
q.connector='or' #**修改关系
q.children.append('maichu__gt',180)
q.children.append('price__lt',600)res= models.Books.objects.filter(q) #filter 也支持直接放q对象,默认还是and关系

 

开启事务

事务ACID

事务回滚

事务确认

 

from django.db import transactiontry:with transaction.atomic():  #开始事务操作# 先创建一个出版社new_publisher = models.Publisher.objects.create(name="火星出版社")# 创建一本书models.Book.objects.create(title="橘子物语",price=11.11,kucun=10,maichu=10,publisher_id=1000  # 指定一个不存在的出版社id)except Exception as e:print(str(e))

 

orm中常用字段及参数

AutoField
int自增列,必须填入参数 primary_key=True。当model中如果没有自增列,则自动会创建一个列名为id的列。CharField  (sql:varchar)
字符类型,必须提供max_length参数, max_length表示字符长度。#****所有字段都有verbose_name 字段注释*****IntegerField
一个整数类型,范围在 -2147483648 to 2147483647。BigIntegerFieldDecimalField(Field)- 10进制小数- 参数:max_digits,小数总长度decimal_places,小数位长度EmailField(CharField):  varchar(254)- 字符串类型,Django Admin以及ModelForm中提供验证机制DateField
日期字段,日期格式  YYYY-MM-DD,相当于Python中的datetime.date()实例。DateTimeField
日期时间字段,格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ],相当于Python中的datetime.datetime()实例。auto_now:每次操作数据的时候,该字段会自动将当前时间更新auto_now_add:创建数据的时候会自动将当前时间记录下来,之后只要不是人为修改,那么一直不变BooleanField(Field)- 布尔值类型数据库存0、1TextField(Field)- 文本类型没有字数限制FileField(Field) -字符- 字符串,路径保存在数据库,文件上传到指定目录- 参数:upload_to = ""      上传文件的保存路径storage = None      存储组件,默django.core.files.storage.FileSystemStorage例如:upload_to = "/data" 会自动将文件保存/data目录下,然后将文件路径保存到数据库        ###外键字段
#django版本不同,级联可能需要手动设置

自定义字段

首先参考常用的字段

                
# 自定义char类型class MyCharField(models.Field):"""自定义的char类型的字段类"""def __init__(self, max_length, *args, **kwargs): # max_length指定字符串宽度self.max_length = max_lengthsuper(MyCharField, self).__init__(max_length=max_length, *args, **kwargs)def db_type(self, connection):"""限定生成数据库表的字段类型为char,长度为max_length指定的值"""return 'char(%s)' % self.max_length  # 返回 'char(32)' 在数据库中就是char类型宽度32  # char类型字段的使用       class Class(models.Model):id = models.AutoField(primary_key=True)title = models.CharField(max_length=25)# 使用自定义的char类型的字段cname = MyCharField(max_length=25)

 

数据库查询优化

ORM语句的特点

惰性查询:只写orm语句,没有使用,orm不会查询数据库。

 

defer 和 only

res=models.Book.objects.all()
print(res) # 要用数据库才查找数据库#获取书籍表中所有的书的名字
res=models.Book.objects.values('title')##only
#获取对象,只有title,没有其他字段。
res=models.Book.objects.only('title')for i in res:print(i.title) #only 括号内的字段,不会走数据库print(i.price) #only 括号外的字段,重新走数据库 all()不需要走数据库#defer
res=models.Book.objects.defer('title')
for i in res:print(i.price)  #defer与only 刚好相反。括号内走数据库,括号外不需要找数据库。

 

select_related 与prefetch_related

与跨表操作有关

res=models.Book.objects.all()
for i in res:print(i.publish.name) #每循环一次就走一次数据库res=models.Book.objects.select_related('publish') #inner join
#select_related内部直接将book与pulish连接起来,然后一次性将大表里的所有数据
#全部封装给查询出来的对象
# 这时候无论.book表数据还是publish数据都无需要走数据查询# select_related括号内只能放外键字段 一对多,一对一
#多对多不行for i in res:print(i.publish.name)#连多表select_related('a__b__c')###prefetch_relatedres=models.Book.objects.prefetch_related('publish')# prefetch_related 实际是子查询
# 子查询的结果分装到对象中
# 用户感觉不出多一个命令for i in res:print(i.publish.name)#联表查询,遇到大表,效率就慢。

 

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/280606.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

记事本状态栏不会自动_如何在记事本中同时启用状态栏和自动换行

记事本状态栏不会自动The status bar in Windows’ Notepad displays the current line number and column number of the cursor location. However, if you find that the Status Bar option on the View menu is grayed out, it may be because you have Word Wrap enabled…

洛谷P2587 [ZJOI2008] 泡泡堂

题目传送门 分析:一道策略游戏题,要求最大期望得分和最小期望得分。首先分析最大,很显然是可以用一种类似于田忌赛马的思维来做,将两队的实力按照从大到小(其实从小到大也可以)排序,然后就按照顺…

极端高温导致澳大利亚断网

西澳大利亚首府珀斯因恶劣天气出现了网络连接问题, 网络故障不是由于暴风雨或闪电引起的,而是极端高温。本周一是珀斯有记录以来第六热的天,当天最高温度达到了44.4℃。因为创纪录的高温,澳大利亚宽带 服务商iiNet在当…

推荐一款采用 .NET 编写的 反编译到源码工具 Reko

今天给大家介绍的是一款名叫Reko的开源反编译工具,该工具采用C#开发,广大研究人员可利用Reko来对机器码进行反编译处理。我们知道.NET 7 有了NativeAOT 的支持,采用NativeAOT 编译的.NET程序 无法通过ILSpy 之类的传统工具得到源码&#xff0…

并行传输数据和串行传输数据_为什么串行数据传输比并行数据传输快?

并行传输数据和串行传输数据SATA hard drive connections are faster than older PATA hard drive connections and the same can be said for external cabling standards, but this is counter-intuitive: why wouldn’t the parallel transmission be faster? SATA硬盘驱动…

得到某月的天数

Calendar timeCalendar.getInstance(); time.clear(); time.set(Calendar.YEAR,2018);//year年 time.set(Calendar.MONTH,1);//Calendar对象默认一月为0,month月 int daytime.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数 System.out.pri…

Django09:图书管理系统笔记/choices用法/ MTV与MVC模型/多对多三种创建方式

图书管理系统笔记 redirect括号内可以直接写url 也可以直接写别名 但如果别名需要参数,必须使用reverse解析。 choices用法 使用场景:能列举完全的数据 #使用方法:xxx_choice #1. get.xxx_display #2. 如果超出范围,则显示原…

业务处理速度变慢?且看IT如何成为救世主

在日常生活的方方面面,我们似乎都在期待着一种即时的便利。比如,用手机购物、订餐、缴费、预约挂号等等。而在企业中,时间与效率可不是一种休闲福利,而是一项重要的商业功能。我们有理由期待,当今史无前例的数字革命正…

微软让卡塔尔世界杯踏入元宇宙

遵守前一篇公众号文章里的承诺,昨天盆盆在视频号里录制了一段5分钟左右的短视频,讲了江森自控和微软Azure,如何帮助卡塔尔世界杯打造基于元宇宙的数字体育馆。Part.1欢迎扫码关注我的视频号(每天更新元宇宙、云计算和数字化的短视频)。Part.2…

洛谷——P1305 新二叉树(新建二叉树以及遍历)

题目描述输入一串二叉树,用遍历前序打出。 输入输出格式输入格式: 第一行为二叉树的节点数n。(n \leq 26n≤26) 后面n行,每一个字母为节点,后两个字母分别为其左右儿子。 空节点用*表示 输出格式: 前序排列的二叉树 输…

插槽1单通道插槽2双通道_相机双存储卡插槽有什么大不了的?

插槽1单通道插槽2双通道If you paid any attention to the launch of Canon and Nikon’s first full frame mirrorless cameras—the EOS R, Z6, and Z7— you’d have noticed that some people were pretty unhappy that they only came with a single card slot—an SD slo…

python 垃圾回收详解

原文:https://zhuanlan.zhihu.com/p/31150408 总纲策略和垃圾回收系统工作内容引用计数详解标记-清除分代收集循环引用编程应用-常见方法ex 过程详解使用建议触发机制参考文献Python垃圾回收机制--完美讲解(Python vs Ruby)Python垃圾回收机制…

Django10:Ajax介绍/发送数据/SweetAlert

Ajax 异步提交 局部刷新 发送方式 1. 浏览器输入url,按enter get 2.a标签href属性 get 3.form表单 get/post 4. ajax get/post ajax 不是编程语言&#xf…

物联网数据终端演进之道

智能手机的普及在最近几年掀起了一股取代企业数据终端的风潮,但正如笔者在一年前便提到过 的,“智能手机难以在企业级应用中得以普及”,这种观点最好的佐证便是时至今日,由于安全性与管理合规的需要,个人计算机用于企业…

mac 不能连接wi-fi_如何阻止Mac自动连接到Wi-Fi网络

mac 不能连接wi-fiYour Mac automatically reconnects to Wi-Fi networks you’ve previously connected to. Starting with macOS High Sierra, you can now tell your Mac not to automatically connect to certain Wi-FI networks. Your Mac will remember the Wi-Fi networ…

“玩转课堂”基本构想

1、项目背景随着互联网科技的高速发展,人们的生活、学习和工作中的许多事情都可以借助互联网来完成,并且反响良好。作为学生,我们切身体会到,能够使用网络平台来进行学习可以节约时间、并且十分方便;而在老师的角度&am…

SQLServer之分离数据库

分离数据库注意事项 要求具有 db_owner 固定数据库角色中的成员资格。 可以分离数据库的数据和事务日志文件,然后将它们重新附加到同一或其他 SQL Server实例。 如果要将数据库更改到同一计算机的不同 SQL Server 实例或要移动数据库,分离和附加数据库会…

django11:自动序列化/批量插入数据/分页器

自动序列化 借助serializers帮你自动完成序列化 from app01 import models from django.core import serializers def ab_se(request):user_queryset models.Userinfo.objects.all()#原始方法user_list []for user_obj in user_queryset:user_list.append({username:user_o…

罗汉塔最少步骤_如何以最少的步骤压缩和密码保护文件?

罗汉塔最少步骤If you have a large batch of files to compress and you want to add password protection to each of them, what is the simplest or quickest way to do so? Today’s SuperUser Q&A post has the answer to a curious reader’s question. 如果要压缩…

IoTSharp中使用X509加密MQTT通讯并实现设备鉴权

IoTSharp支持MQTT协议通过 TLS 1.2 加密通讯, 并可以通过X509证书进行设备认证登录。基本配置在 appsettings.Production.json中需要 指定域名, 并设置EnableTls为true"MqttBroker":{"DomainName":"http://demo.iotsharp.net:2…