res = models.Book.objects.all()
# 如果此时直接运行,不调用这个结果,终端将什么也不会打印出来
# 原因:惰性查询,减少不必要的数据库操作,降低数据库的压力

only 和 defer

only 的优化机制:

res = models.Book.objects.only('title')		# 括号内查询的字段可以有多个
print(res) # 查询一次,打印一条sql查询语句
for i in res:
print(i.title) # 查询一次,打印一条sql查询语句
print(i.price) # 有几个对象,就查询几次,打印几条sql查询语句

defe 的优化机制:

res = models.Book.objects.defer('title')	# 括号内查询的字段可以有多个
print(res) # 查询一次,打印一条sql查询语句
for i in res:
print(i.title) # # 有几个对象,就查询几次,打印几条sql查询语句
print(i.price) # 查询一次,打印一条sql查询语句

only 与 defer 的区别:

共同点:两者括号内都可以放数据库字段,查询结果都是一个列表套一个个的数据对象。

不同点:

  • only:数据对象里面封装了括号内查询的字段,直接点这个括号内字段属性不需要再次查询数据库

    ​ 如果查询括号内没有的字段,每查询一次,就需要去数据库中重新查询,效率低

  • defer:数据库中封装了相当于除括号内查询的字段,直接点这个括号内字段属性需要再次查询数据库,如果查询括号内没有的字段,就不需要再次查询数据库,效率高

select_related 和 prefetch_related

select_related :

res = models.Book.objects.select_related('publish')	# 支持放多个外键字段
print(res) # 查询外键字段,连表查询
for i in res:
print(i.publish.name) # 连表查询一次,一条sql语句
print(i.title) # 连表查询一次,一条sql语句

prefetch_related:

res = models.Book.objects.prefetch_related('publish')	# 支持放多个外键字段
print(res) # 查询外键字段,子查询
for i in res:
print(i.publish.name) # 子查询查询一次,一条sql语句
print(i.title) # 子查询查询一次,一条sql语句

select_related 和 prefetch_related 的区别:

共同点:括号内只能放外键字段,并且外键字段关系只能是一对多、一对一,不能是多不多

不同点:

  • select_related:内部是连表(left/right join)查询,查询的时候不需要再次查询数据库
  • prefetc_related:内部是子查询,查询多张表,将查询结果封装到对象中,如果括号内外键字段比较多,则查询次数较多。

结合实际情况,哪种查询更加好?

select_related 查询需要连表,数据量大可能耗时比较久

prefetc_related 查询多张表,数据量大可能查询次数多一点,但是时间较快

ORM字段参数 choices

字段参数choices可以按照提前设计好的对应关系,存取对应真正的数据

models.py:
class User(models.Model):
user = models.CharField(max_length=64)
pwd = models.IntegerField()
gender_choices = (
(1,'男'),
(2,'女')
)
gender = models.IntegerField(choices=gender_choices) 手动插入数据:
id user pwd gender
1 qinyj 123 1
2 jack 123 2
from app01 import models
user_obj = models.User.objects.get(pk=1)
print(user_obj.get_gender_display())

只要是choices字段类型,在获取值的时候需要这样写:get_字段名_display()

Django之ORM查询优化的更多相关文章

  1. django之ORM的查询优化、Ajax 06

    目录 ORM查询优化 only与defer select_related与prefetch_related查询优化 choices参数 MTV与MVC模型 Ajax简介 AJAX常见应用情景 AJAX ...

  2. orm查询优化 MTV和MVC模型 字段的chioces参数 Ajax

    目录 一.ORM查询优化 1. all()查询 2. only()/defer()方法 (1)only()方法 (2)defer()方法 3. select_related()/prefetch_re ...

  3. day09 orm查询优化相关

    day09 orm查询优化相关 今日内容概要 orm字段相关补充 orm查询优化相关 orm事务操作 图书管理系统练习 今日内容详细 orm事务操作 """ 事务:ACI ...

  4. python——Django(ORM连表操作)

    千呼万唤始出来~~~当当当,终于系统讲了django的ORM操作啦!!!这里记录的是django操作数据库表一对多.多对多的表创建及操作.对于操作,我们只记录连表相关的内容,介绍增加数据和查找数据,因 ...

  5. Python’s SQLAlchemy vs Other ORMs[转发 3]Django's ORM

    Django's ORM Django is a free and open source web application framework whose ORM is built tightly i ...

  6. 将SALT_STACK的JOB-CACHE放到数据库中,而建库用DJANGO的ORM完成

    下面包括了SALT_MASTER的配置,及DJANGO的ORM里更改默认表名称,更改默认字段名称(里面有个RETURN),更改默认ID索引... 一个下午有和它磨来磨去... 感谢鹏龙,感谢高远..: ...

  7. Django:之ORM、CMS和二维码生成

    Django ORM Django 的数据库接口非常好用,我们甚至不需要知道SQL语句如何书写,就可以轻松地查询,创建一些内容,所以有时候想,在其它的地方使用Django的 ORM呢?它有这么丰富的 ...

  8. Django的ORM实现数据库事务操作

    在Django中实现数据库的事务操作 在学习MySQL数据库时,MySQL数据库是支持原子操作的. 什么是数据库的原子操作呢??打个比方,一个消费者在一个商户里刷信用卡消费. 交易正常时,银行在消费者 ...

  9. 第十九章 Django的ORM映射机制

    第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...

随机推荐

  1. 9.3.2 The force and release procedural statements

    Frm: IEEE Std 1364™-2001, IEEE Standard Verilog® Hardware Description Language Another form of proce ...

  2. jquery操作html元素之(设置内容和属性)

    设置内容 - text().html() 以及 val() 我们将使用前一章中的三个相同的方法来设置内容: text() - 设置或返回所选元素的文本内容 html() - 设置或返回所选元素的内容( ...

  3. jupyter安装_pip法

    安装jupyter notebook的流程(注意python至少需要3.6版本) python -m pip install jupyter  #安装jupyter python -m pip ins ...

  4. 天道神诀---DHCP服务(下篇)

    DHCP作用域详解 subnet  定义一个作用域 netmask  定义作用域的掩码 range  允许发放的IP范围 option routers 指定网关地址 option domain-nam ...

  5. centos6.5离线安装pandas

    由于笔记本跑不动很多大赛的数据,遂转至申请的虚拟机(centos6.5)中,奈何学校的虚拟机没网,就开始了离线安装pandas的道路,当中有踩了好些坑,于是便产生了这篇文章~ 首先,自带的python ...

  6. await和async

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  7. 获取linux性能数据

    import reimport osimport sysimport jsonimport socketfrom urllib import request,parseimport urllibfro ...

  8. [NOIP2005] 过河【Dp,思维题,缩点】

    Online Judge:Luogu P1052 Label:Dp,思维题,缩点,数学 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子 ...

  9. SQL一些记录

    1,2字段约束create unique index [索引名] on 软件信息表(S_SName,S_Edition)

  10. RabbitMQ 连接不上

    问题 [org.springframework.amqp.AmqpIOException: java.io.IOException] 解决 username: guest password: gues ...