博客
关于我
Django的defer和only方法详解
阅读量:229 次
发布时间:2019-02-28

本文共 781 字,大约阅读时间需要 2 分钟。

Django ORM自带的defer和only方法虽说不像filter, exclude, order_by这几个方法那么常见,但用起来还是可以优化数据库查询的。今天小编我就带你看看如何使用这两种方法。

Defer方法

Defer方法的用途是查询数据库时跳过指定的字段,比如下面查询时将跳过每篇Entry的headline和body字段。当你不需要在查询结果中使用headline和body字段时,使用defer方法可以防止将headline和body载入内存,从而节省空间。一篇文章可能没啥关系,但文章很多时,节省的内存空间不可忽视。

Entry.objects.defer("headline", "body")

Defer方法可以和filter, exclude方法联用,其顺序无关紧要,如下所示:

Entry.objects.defer("body").filter(rating=5).defer("headline")

如果你要载入所有字段,只需要设置defer(None)

my_queryset.defer(None)

Only方法

Only方法与defer方法作用类时,只不过only方法是指定需要载入的字段。比如下面查询将只会载入body和pub_date。

Entry.objects.only("body", "pub_date")

使用only方法时一定要非常注意它的顺序,它的执行以最后一个为准。下例将只会载入headline。

Entry.objects.only("body", "rating").only("headline")

only方法与defer方法可以联用,但一定要注意先后顺序。下例只会载入headline。

Entry.objects.only("headline", "body").defer("body")

转载地址:http://sytp.baihongyu.com/

你可能感兴趣的文章
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>
NetBeans之改变难看的JSP脚本标签的背景色...
查看>>
netbeans生成的maven工程没有web.xml文件 如何新建
查看>>
netcat的端口转发功能的实现
查看>>
NetCore 上传,断点续传,可支持流上传
查看>>
Netcraft报告: let's encrypt和Comodo发布成千上万的网络钓鱼证书
查看>>
Netem功能
查看>>
netfilter应用场景
查看>>
Netflix:当你按下“播放”的时候发生了什么?
查看>>
Netflix推荐系统:从评分预测到消费者法则
查看>>
netframework 4.0内置处理JSON对象
查看>>
Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)
查看>>
Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(十一)备份
查看>>
netlink2.6.32内核实现源码
查看>>
netmiko 自动判断设备类型python_Python netmiko模块的使用
查看>>
NetMizer 日志管理系统 多处前台RCE漏洞复现
查看>>
NetMizer-日志管理系统 dologin.php SQL注入漏洞复现(XVE-2024-37672)
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>