django的orm操作优化

models.py

from django.db import models

class Author(models.Model):
name = models.CharField(max_length=16)
age = models.IntegerField() class Book(models.Model):
authors = models.ManyToManyField('Author')
pubs = models.ForeignKey("Publish",on_delete=models.CASCADE)
title = models.CharField(max_length=32)
pubtime = models.DateField() class Publish(models.Model):
name = models.CharField(max_length=32)

优化一:尽量不查对象,能用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. 【Django】ORM操作#2

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

  2. Django之ORM操作

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

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

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

  4. Django之ORM操作(***)

    Django之ORM操作(***) http请求的流程: url--> 视图view(模板+数据库) --> ORM的功能: 可以转换SQL语句,并做操作. ORM操作数据表: -创建表: ...

  5. 【Django】ORM操作#1

    目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...

  6. Django之ORM操作(重要)

    Django ORM操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条   <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给 ...

  7. Django中ORM操作

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

  8. Django的ORM操作

    ORM操作 select * from tb where id > 1 # 对应关系 models.tb.objects.filter(id__gt=1) models.tb.objects.f ...

  9. Django之ORM操作总结

    Django之ORM总结 表结构 from django.db import models # 一对多:班级与学生 # 多对多:班级与老师 # Create your models here. #创建 ...

随机推荐

  1. vue 和react中子组件分别如何向父组件传值

    vue子组件和父组件双向传值: 子: Vue.component("childComponent",{ template:`<div><p @click='pos ...

  2. Scrapy抓取jobbole数据

    1.python版本3.6.1 2.python编辑器:JetBrains PyCharm 2.安装virtualenvwrapper-win pip3 install virtualenvwrapp ...

  3. CentOS7系统局域网内配置本地yum源解决cannot find a valid baseurl for repo

    一.     问题详情 因为服务器无法连接外网,所有直接用yum安装某些功能将受到影响,报错如下: Error: Cannot find a valid baseurl for repo: base ...

  4. tree 数状型结构显示目录下的内容

    1. 命令功能 tree中文意思“树”,以树形结构显示目录内容.. 2. 语法格式 tree  [option]   [directory] tree  选项   目录 3. 使用范例 当最小化安装l ...

  5. layui树形表格支持非异步和异步加载

    layui树形表格支持非异步和异步加载. 仓库地址:https://gitee.com/uniqid/ 使用示例如下: <div class="uui-admin-common-bod ...

  6. 手工实现hashset

    package cn.study.lu.four; import java.util.*; /** * 手工实现hashmap,加深理解底层原理 * @author Administrator * * ...

  7. Python---基础-运算符int和range函数

    这行代码是什么意思 if not (money<100) money >= 100 -------------------------------假设有x = 1, y = 2, z = ...

  8. Oracle RAC运维所遇问题记录二

    oracle12c RAC源端与Dataguard目标端实时同步,因业务需求需要在源端增加PDB 1. 源端添加PDB CREATE PLUGGABLE DATABASE kdlxpdb admin ...

  9. java通配符写法

    有时候我们会遇到这样的需求,需要把一个报文里的某些参数项通过通配符的形式配置成我们需要的结果值插入回报文中. String filetext = "<cn>#用户身份ID(主账号 ...

  10. C#通过文件头判断文件的类型(不是后缀名)

    FileStream fs=new FileStream(@"D:\6",FileMode.Open,FileAccess.Read); BinaryReader reader= ...