Django 数据库访问性能优化
使用标准的数据库优化技术:
在进行Django数据库访问性能优化之前,首先应该使用标准的数据库技术对其进行优化,比如给字段加索引,通过使用
django.db.models.Field.db_index来给一个Django模型类的字段加索引,设置这个属性字段的Field.db_index=True。注:django对model中的
fk和unique = True的字段将自动创建索引。理解Django中QuerySet的工作机制对数据库访问优化至关重要:
QuerySet是懒加载的,它只有在需要的时候才会被执行,并且会将执行的结果保存在内存中。
理解Django中QuerySet的缓存机制:
QuerySet对调用方法是不执行缓存的。比如下面的两端代码,其中一个会被缓存,另一个不会:
>>> entry = Entry.objects.get(id=1) >>> entry.blog # Blog对象会被从数据库查询出来 >>> entry.blog # 第二次访问的缓存对象,不会再次执行查询但是对于调用的查询方法,是不会被缓存的:
>>> entry = Entry.objects.get(id=1) >>> entry.authors.all() # 第一次会执行查询 >>> entry.authors.all() # 第二次会再执行一次查询使用模板语言中的with标签:
在视图模板中,针对QuerySet对象使用
with标签,可以让数据被缓存起来使用。使用
iterator()方法:对于缓存的QuerySet使用
iterator()方法。将查询计算操作放在数据库中完成,不要在Python代码中完成。
使用
filter,exclude完成查询过滤;F()查询表达式;使用聚合函数来完成数据库聚合操作。
使用
QuerySet.extra()明确的指出要查询的字段。对于复杂的数据库查询操作,使用原生SQL实现。
尽量一次查询出所有需要的信息。
只查询需要的数据:
某些情况下,只使用
QuerySet.values()和values_list()方法,查询出符合条件的结果集而不是完整的对象结果集;某些情况下,只使用
QuerySet.defer()和only()过滤数据。
如果只是查询集合的数量,使用
QuerySet.count()函数,而不是len(QuerySet);如果想知道某个记录是否包含在某个结果集中,使用
QuerySet.exists()函数;避免过多的使用
count()和exists()函数;对于批量更新和删除操作使用
QuerySet.update()和QuerySet.delete();理解
QuerySet.select_related()方法:select_related()会在查询过程中尽量深入的查询关联数据,这样在需要查询大量外键的数据时非常有用,如:
>>> e=Entry.objects.get(id=5) #这部操作会查询数据库 >>> b=e.blog #该操作会再次查询数据库而采用
select_related()查询的效果是:
>>> e=Entry.objects.select_related().get(id=5) #这步操作会查询数据库 >>> b=e.blog #不会再次查询数据库如果需要查询对象的外键,则使用外键字段而不是使用关联的对象的主键,比如:
>>> entry.blog_id #应该使用这种方式 >>> entry.blog.id #不要使用这种方式
Django 数据库访问性能优化的更多相关文章
- 数据库访问性能优化 Oracle
特别说明: 1. 本文只是面对数据库应用开发的程序员,不适合专业DBA,DBA在数据库性能优化方面需要了解更多的知识: 2. 本文许多示例及概念是基于Oracle数据库描述,对于其它关系型数据库也 ...
- Oracle学习总结(8)—— 面向程序员的数据库访问性能优化法则
特别说明: 1. 本文只是面对数据库应用开发的程序员,不适合专业DBA,DBA在数据库性能优化方面需要了解更多的知识: 2. 本文许多示例及概念是基于Oracle数据库描述,对于其它关系型数据库也 ...
- spring配置druid连接池和监控数据库访问性能
Druid连接池及监控在spring配置如下: <bean id="dataSource" class="com.alibaba.druid.pool.DruidD ...
- 【转载】HBase 数据库检索性能优化策略
转自:http://www.ibm.com/developerworks/cn/java/j-lo-HBase/index.html 高性能 HBase 数据库 本文首先介绍了 HBase 数据库基本 ...
- 【Spring Boot&&Spring Cloud系列】提高数据库访问性能
前言 使用关系型数据库的应用系统的性能瓶颈最终还是数据库.随着业务的迅速增长,数据量会不断增大,会逐渐暴露关系型数据库的弱点,性能会大幅度的降低 项目地址:https://github.com/And ...
- Java面试准备十六:数据库——MySQL性能优化
2017年04月20日 13:09:43 阅读数:6837 这里只是为了记录,由于自身水平实在不怎么样,难免错误百出,有错的地方还望大家多多指出,谢谢. 来自MySQL性能优化的最佳20+经验 为查询 ...
- 数据库SQL性能优化
1.in与exists的效率比较 in是把外表和内表作hash 连接,而exists 是对外表作loop 循环,每次loop 循环再对内表进行查询.一直以来认为exists 比in 效率高的说法是不准 ...
- oracle数据库应用性能优化经验(培训讲义)
这是我给公司同事做的内部培训ppt的讲义,给大家分享一下.这是培训大纲,ppt在找地方上传,等找到了会把链接发在这里 . 暂时放在csdn上,赚点下载积分:https://download.csdn. ...
- HBase 数据库检索性能优化策略--转
https://www.ibm.com/developerworks/cn/java/j-lo-HBase/index.html HBase 数据表介绍 HBase 数据库是一个基于分布式的.面向列的 ...
随机推荐
- 创建Ajax兼容
var request = new XMLHttpRequest(); IE7以下: var request = new ActiveXObject("Microsoft.XMLHTTP&q ...
- 《实战Java高并发程序设计》读书笔记二
第二章 Java并行程序基础 1.线程的基本操作 线程:进程是线程的容器,线程是轻量级进程,是程序执行的最小单位,使用多线程而不用多进程去进行并发程序设计是因为线程间的切换和调度的成本远远的小于进程 ...
- 2019年4月22日A股暴跌行情思考
2019年4月22日A股暴跌行情思考 原因:股指期货松绑 盘面:小幅高开,单边下跌 操作: 总结: 股指期货松绑,周末媒体YY大盘暴涨,不排除空头故意借助媒体来诱多,然开盘后暴跌. 预期过于一致时,需 ...
- 使用maven搭建web项目
在pom.xml中添加java ee相关的三个依赖包:<scope> jar的有效范围 provided 表示编译期生效,不会打包发布到 tomcat 中 <properties&g ...
- Python之时间和日期模块
1.import time 先要导入时间模块 1)time.time()得到当前的时间,返回的是时间戳,表示自1970年1月1日起到程序运行时的秒数 import time print(time.ti ...
- solve License Key is legacy format when use ACTIVATION_CODE activate jetbrains-product 2019.3.1
1.the java-agent and ACTIVATION_CODE can get from this site:https://zhile.io/2018/08/25/jetbrains-li ...
- nginx访问目录是没加/的重定向控制
static 模块提供了root与alias功能:发现目标是目录时:但URI末尾未加/时:会返回301重定向:重定向后会加/ 指令 Syntax: server_name_in_redirect on ...
- Java记录2---包的使用
javac -d . A.java -d 表示自动生成包层 . 表示这个包层在当前目录下建立 package link.roland;//package 语句必须是第一条语句 //该语句表示把该文件中 ...
- ORACLE CPU过高的sql查询
1. 根据占用CPU高的进程号来查询这个进程执行的SQL语句: CPU过高的进程号: #首先找到CPU过高的进程号 # top -bn1 是静态找到占用最高的进程 [root@localhost ...
- Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间
一.Apache访问日志不记录静态文件 网站大多元素为静态文件,如图片.css.js等,这些元素可以不用记录 vim /usr/local/apache2.4/conf/extra/httpd-vho ...