1. 使用标准的数据库优化技术:

    在进行Django数据库访问性能优化之前,首先应该使用标准的数据库技术对其进行优化,比如给字段加索引,通过使用 django.db.models.Field.db_index 来给一个Django模型类的字段加索引,设置这个属性字段的Field.db_index=True

    注:django对model中的fkunique = True的字段将自动创建索引。

  2. 理解Django中QuerySet的工作机制对数据库访问优化至关重要:

    QuerySet是懒加载的,它只有在需要的时候才会被执行,并且会将执行的结果保存在内存中。

  3. 理解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() # 第二次会再执行一次查询
    
    
  4. 使用模板语言中的with标签:

    在视图模板中,针对QuerySet对象使用with标签,可以让数据被缓存起来使用。

  5. 使用iterator()方法:

    对于缓存的QuerySet使用iterator()方法。

  6. 将查询计算操作放在数据库中完成,不要在Python代码中完成。

    1. 使用filter,exclude完成查询过滤;

    2. F()查询表达式;

    3. 使用聚合函数来完成数据库聚合操作。

  7. 使用QuerySet.extra()明确的指出要查询的字段。

  8. 对于复杂的数据库查询操作,使用原生SQL实现。

  9. 尽量一次查询出所有需要的信息。

  10. 只查询需要的数据:

    1. 某些情况下,只使用 QuerySet.values()values_list()方法,查询出符合条件的结果集而不是完整的对象结果集;

    2. 某些情况下,只使用 QuerySet.defer()only()过滤数据。

  11. 如果只是查询集合的数量,使用QuerySet.count()函数,而不是len(QuerySet)

  12. 如果想知道某个记录是否包含在某个结果集中,使用 QuerySet.exists()函数;

  13. 避免过多的使用 count()exists() 函数;

  14. 对于批量更新和删除操作使用 QuerySet.update()QuerySet.delete()

  15. 理解 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 #不会再次查询数据库
  16. 如果需要查询对象的外键,则使用外键字段而不是使用关联的对象的主键,比如:


    >>> entry.blog_id #应该使用这种方式 >>> entry.blog.id #不要使用这种方式

Django 数据库访问性能优化的更多相关文章

  1. 数据库访问性能优化 Oracle

    特别说明: 1.  本文只是面对数据库应用开发的程序员,不适合专业DBA,DBA在数据库性能优化方面需要了解更多的知识: 2.  本文许多示例及概念是基于Oracle数据库描述,对于其它关系型数据库也 ...

  2. Oracle学习总结(8)—— 面向程序员的数据库访问性能优化法则

    特别说明: 1.  本文只是面对数据库应用开发的程序员,不适合专业DBA,DBA在数据库性能优化方面需要了解更多的知识: 2.  本文许多示例及概念是基于Oracle数据库描述,对于其它关系型数据库也 ...

  3. spring配置druid连接池和监控数据库访问性能

    Druid连接池及监控在spring配置如下: <bean id="dataSource" class="com.alibaba.druid.pool.DruidD ...

  4. 【转载】HBase 数据库检索性能优化策略

    转自:http://www.ibm.com/developerworks/cn/java/j-lo-HBase/index.html 高性能 HBase 数据库 本文首先介绍了 HBase 数据库基本 ...

  5. 【Spring Boot&&Spring Cloud系列】提高数据库访问性能

    前言 使用关系型数据库的应用系统的性能瓶颈最终还是数据库.随着业务的迅速增长,数据量会不断增大,会逐渐暴露关系型数据库的弱点,性能会大幅度的降低 项目地址:https://github.com/And ...

  6. Java面试准备十六:数据库——MySQL性能优化

    2017年04月20日 13:09:43 阅读数:6837 这里只是为了记录,由于自身水平实在不怎么样,难免错误百出,有错的地方还望大家多多指出,谢谢. 来自MySQL性能优化的最佳20+经验 为查询 ...

  7. 数据库SQL性能优化

    1.in与exists的效率比较 in是把外表和内表作hash 连接,而exists 是对外表作loop 循环,每次loop 循环再对内表进行查询.一直以来认为exists 比in 效率高的说法是不准 ...

  8. oracle数据库应用性能优化经验(培训讲义)

    这是我给公司同事做的内部培训ppt的讲义,给大家分享一下.这是培训大纲,ppt在找地方上传,等找到了会把链接发在这里 . 暂时放在csdn上,赚点下载积分:https://download.csdn. ...

  9. HBase 数据库检索性能优化策略--转

    https://www.ibm.com/developerworks/cn/java/j-lo-HBase/index.html HBase 数据表介绍 HBase 数据库是一个基于分布式的.面向列的 ...

随机推荐

  1. spring整合web项目

    Web项目如何初始化SpringIOC容器 :思路:当服务启动时(tomcat),通过监听器将SpringIOC容器初始化一次(该监听器 spring-web.jar已经提供),web项目启动时 ,会 ...

  2. Cisco Umbrella WLAN

    Cisco Umbrella WLAN在域名系统(DNS)级别提供云交付网络安全服务,可自动检测已知和紧急威胁. 此功能允许您在实际恶意攻击之前阻止托管恶意软件,僵尸网络和网络钓鱼的站点. Cisco ...

  3. Linux终端的一些快捷键命令

    一.初识linux的终端种类:本地.远程 查看本终端命令: #tty 命令,看到当前所处的终端 #(w)who 命令,看到系统中所有登录的用户 其中,tty 终端为表示在本地命令行模式下打开的终端:p ...

  4. PyCharm调试方法

    1.调试部分代码以后继续执行剩余代码,点击Resume Program:

  5. #P4770 [NOI2018]你的名字 的题解

    题目背景 实力强大的小A 被选为了ION2018 的出题人,现在他需要解决题目的命名问题. 题目描述 小A 被选为了ION2018 的出题人,他精心准备了一道质量十分高的题目,且已经把除了题目命名以外 ...

  6. ajax的XmlHttpRequest对象常用方法

    onreadystatechange用于检测readyState状态的改变,当readyState的状态发生改变的时候调用回调

  7. sftp和FTP

    sftp 是一个交互式安全文件传输协议的传输程式.它类似于 ftp也叫internet网络文件协议, 但它进行加密传输,比FTP有更高的安全性.下边就简单介绍一下如何远程连接主机,进行文件的上传和下 ...

  8. 【摘录自MDN】客户端和服务器

    客户端和服务器 连接到互联网的计算机被称作客户端和服务器.下面是一个简单描述它们如何交互的图表: 客户端是典型的Web用户入网设备(比如,你连接了Wi-Fi的电脑,或接入移动网络的手机)和设备上可联网 ...

  9. Python磁力获取器命令行工具 torrent-cli

    作为一个搞代码的,找资源这种事肯定不能像普通人一样打开百度盲目查找,你需要写个爬虫工具来帮你完成这件事情啦! 兼容环境 Windows/Linux/MacOs 安装 pip 安装 $ pip inst ...

  10. git合并分支到主干

    1.从当前分支切换主干 git checkout master 2.更新主干内容到本地 git pull 4.提交分支,并将分支merge到主干 git merge dev 5: i键后输入备注  输 ...