提升orm操作性能注意的点

优化一:尽量不查对象,能用values就是用values

直接使用对象查询的结果是5条sql语句

def youhua(request):
# 使用对象查
obj_list = models.Book.objects.all()
for obj in obj_list:
print(obj.title,obj.pubs.name) return render(request,"youhua.html")

使用values查询只执行了1条sql,会自动进行连表查询

def youhua(request):
# 使用values
obj_list = models.Book.objects.values('title', 'pubs__name')
for obj in obj_list:
print(obj['title'], obj['pubs__name']) return render(request,"youhua.html")

优化二:select_related('classes')

使用select_related('classes')

适用于:多对一 ,一对一查询添加select_related()方法,括号中是外键字段 。会进行连表查询

def youhua(request):
# 使用对象查
obj_list = models.Book.objects.all().select_related('pubs')
for obj in obj_list:
print(obj.title, obj.pubs.name) return render(request,"youhua.html")

优化三:prefetch_related()

使用prefetch_related(),多对一,

def youhua(request):

    obj_list = models.Book.objects.all().prefetch_related("pubs")
for obj in obj_list:
print(obj.title,obj.pubs.name) return render(request,"youhua.html")

使用prefetch_related(),多对多,

def youhua(request):

    obj_list = models.Book.objects.all()
for obj in obj_list:
print(obj.title,obj.authors.all()) return render(request,"youhua.html")

def youhua(request):

    obj_list = models.Book.objects.all().prefetch_related("authors")
for obj in obj_list:
print(obj.title,obj.authors.all()) return render(request,"youhua.html")

优化四:only()指定查询字段

直接查询的情况,会将所有字段都查询出来

def youhua(request):

    obj_list = models.Book.objects.all()
for obj in obj_list:
print(obj.title) return render(request,"youhua.html")

查询时指定某些字段查询,使用only指定字段只会查我们需要的那个字段。

def youhua(request):

    obj_list = models.Book.objects.all().only('title')
for obj in obj_list:
print(obj.title) return render(request,"youhua.html")

优化五:defer() 查询时指定排除某些字段和only相反

如果我们需要的字段较多,不需要的较少,可以使用defer排除

def youhua(request):

    obj_list = models.Book.objects.all().defer('title')
for obj in obj_list:
print(obj.pubtime) return render(request,"youhua.html")

注:如果排除的字段,还要查会增加查询负担,当然查询指定字段之外的字段也会增加查询负担。

Django中ORM操作提升性能的更多相关文章

  1. 1122 django中orm操作

    目录 1. 静态文件的配置 手动静态文件的访问资源 静态文件的动态绑定 2.request方法 2.1 请求方式 2.2 获取前端的请求方式 request.method 2.3 request方法 ...

  2. Django中ORM操作

    ORM操作: class UserInfo(models.Model): username = models.CharField(max_length=32) password = models.Ch ...

  3. 6月20日 Django中ORM介绍和字段、字段参数、相关操作

    一.Django中ORM介绍和字段及字段参数 二.Django ORM 常用字段和参数 三.Django ORM执行原生SQL.在Python脚本中调用Django环境.Django终端打印SQL语句 ...

  4. Django之ORM操作

    Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...

  5. django中orm使用的注意事项

    必备小知识点 <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者 ...

  6. 【Django】ORM操作#2

    目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...

  7. Django中ORM介绍和字段及其参数

    ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述 ...

  8. Django之ORM操作(聚合 分组、F Q)

    Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.   键的名 ...

  9. Django中ORM介绍和字段及字段参数 Object Relational Mapping(ORM)

    Django中ORM介绍和字段及字段参数   Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...

随机推荐

  1. MySQL_(Java)使用JDBC创建用户名和密码校验查询方法

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL数据库中的数据,数据库名garysql,表名garytb,数据库中存在的用户表 通过JDBC对MySQL中的数据用户名和密码 ...

  2. 线程系列2--Java线程的互斥技术

    java的多线程互斥主要通过synchronized关键字实现.一个线程就是一个执行线索,多个线程可理解为多个执行线索.进程有独立的内存空间,而进程中的线程则是共享数据对象资源.这样当多个执行线索在C ...

  3. uniapp导航栏自定义按钮及点击事件

    本文链接:https://blog.csdn.net/qq_33807889/article/details/89945674第一步:显示按钮假设页面名称为:AddSort 在pages.json中找 ...

  4. Fastadmin 写关联命名时,最好前后台用同一个model,方便管理(会出现命名空间问题)

    1.php think crud -t test --relation=category(外键表1) --relation=admin(外键表2) --relationforeignkey=categ ...

  5. Java-UncaughtExceptionHandler 捕获线程异常

    实现 UncaughtExceptionHandler 类,重写 uncaughtException 方法. public class MyUncaughtExceptionHandler imple ...

  6. LC 712. Minimum ASCII Delete Sum for Two Strings

    Given two strings s1, s2, find the lowest ASCII sum of deleted characters to make two strings equal. ...

  7. LC 406. Queue Reconstruction by Height

    Suppose you have a random list of people standing in a queue. Each person is described by a pair of ...

  8. 关于oracle下提示ORA-00904:Invalid identifier错误的问题

    转自:https://blog.csdn.net/suleil1/article/details/49471549 今天在建表后对数据进行插入,遇到这个恶心人的ORA-00904:Invalid id ...

  9. java集合(List,Set,Map)详细总结

    一,集合的由来: 数组是长度是固定的,当添加的元素超过数组的长度时需要对数组重新定义,太麻烦了,java内部给我们提供了集合类,能存储任意对象,长度是可以改变的,随着元素的增加而增加,随着元素的减少而 ...

  10. LoadRunner中的Web 函数列表

    LoadRunner中的Web 函数列表 web test LoadRunner fuction_list D:\Program Files (x86)\Mercury Interactive\Mer ...