淺談django orm 優(yōu)化
orm優(yōu)化
1.數(shù)據(jù)庫(kù)技術(shù)進(jìn)行優(yōu)化,包括給字段加索引,設(shè)置唯一性約束等等;
2.查詢過(guò)濾工作在數(shù)據(jù)庫(kù)語(yǔ)句中做,不要放在代碼中完成(看情況);
3.如果要一次查詢出集合的數(shù)量,使用count函數(shù),而不是len函數(shù),但是如果后面還需要到集合,那就用len,因?yàn)閏ount還需要進(jìn)行一次數(shù)據(jù)庫(kù)的操作;
4.避免過(guò)多的使用count和exists函數(shù);
5.如果需要查詢對(duì)象的外鍵,則使用外鍵字段而不是使用關(guān)聯(lián)的外鍵的對(duì)象的主鍵;
例子:
a.b_id # 正確 a.b.id # 錯(cuò)誤
6.在通過(guò)all語(yǔ)句查詢時(shí),不要做跨表查詢,只查詢當(dāng)前表中有的數(shù)據(jù),否則查詢語(yǔ)句的性能會(huì)下降很多;
比如:a表存在外鍵b表
a.b.all() # 錯(cuò)誤
7.如果想要查詢其他表的數(shù)據(jù),則加上select_related(ForeignKey字段名,其實(shí)就是主動(dòng)聯(lián)表查詢,性能也會(huì)下降),如果有多個(gè),則在括號(hào)中加上;
8.加only參數(shù)是從查詢結(jié)果中只取某個(gè)字段,而另外一個(gè)defer方法則是從查詢結(jié)果中排除某個(gè)字段;
9.不要獲取你不需要的東西,可以通過(guò)values和value_list實(shí)現(xiàn);
values返回的是字典數(shù)組,比如:[{'key1': value1, 'key2': value2}, {'key1': value3, 'key2': value4}]
value_list返回的是tuple數(shù)組 [('value1', 'value2'), ('value3', 'value4')]
value_list+flat=True返回的是數(shù)組 ['value1', ...]
10.如果想知道是否存在至少一個(gè)結(jié)果,使用exists,而不是使用if QuerySet;但是如果后面需要用到前面的QuerySet,那就可以使用if 判斷;
# Don't waste a query if you are using the queryset books = Book.objects.filter(..) if len(books) > 5: do_stuff_with_books(books) # If you aren't using the queryset use count books = Book.objects.filter(..) if books.count() > 5: do_some_stuff() # But never if len(Book.objects.filter(..)) > 5: do_some_stuff()
11.在任何位置使用QuerySet.exists()或者QuerySet.count()都會(huì)導(dǎo)致額外的查詢;
12.不要做無(wú)所謂的排序,排序并非沒(méi)有代價(jià),每個(gè)排序的字段都是數(shù)據(jù)庫(kù)必須執(zhí)行的操作;
13.如果要插入多條數(shù)據(jù),則使用bulk_create來(lái)批量插入,減少sql查詢的數(shù)量;
14.對(duì)于緩存的QuerySet對(duì)象使用with標(biāo)簽,可以讓數(shù)據(jù)被緩存起來(lái)使用;
15.使用QuerySet.extra明確的指出要查詢的字段;
16.批量的更新和刪除則使用Queryset.update和delete函數(shù),但是更新操作注意對(duì)象的緩存;
17.使用QuerySet.Iterator迭代大數(shù)據(jù);
當(dāng)你獲得一個(gè)queryset的時(shí)候,django會(huì)緩存下來(lái),保存在內(nèi)存中,如果需要對(duì)queryset進(jìn)行多次的循環(huán),那么這種緩存無(wú)可厚非; 但是如果你只需要進(jìn)行一次的循環(huán),那么其實(shí)并不需要緩存,這個(gè)使用就可以使用iterator;
比如:
for book in Books.objects.all().iterator(): do_stuff(book)
18.如果想判斷是否存在外鍵,只需要判斷外鍵的id即可;
19.不要在循環(huán)中查詢,而是提前取出,并且做好映射關(guān)系,這樣在循環(huán)中直接通過(guò)字典的形式獲取到;
20.當(dāng)計(jì)算出一個(gè)QuerySet的時(shí)候,如果還需要進(jìn)行多次循環(huán)的話,則可以先保留著這個(gè)緩存,但是如果只是使用一次的話,沒(méi)有必要使用到緩存;
python優(yōu)化:
1.排序盡量使用 .sort(), 其中使用 key 比 cmp 效率更高
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- django框架使用orm實(shí)現(xiàn)批量更新數(shù)據(jù)的方法
- Django使用詳解:ORM 的反向查找(related_name)
- Django ORM 查詢表中某列字段值的方法
- Django基于ORM操作數(shù)據(jù)庫(kù)的方法詳解
- Django ORM 聚合查詢和分組查詢實(shí)現(xiàn)詳解
- Django ORM框架的定時(shí)任務(wù)如何使用詳解
- Django中ORM表的創(chuàng)建和增刪改查方法示例
- django的ORM模型的實(shí)現(xiàn)原理
- 基于Django ORM、一對(duì)一、一對(duì)多、多對(duì)多的全面講解
- django 常用orm操作詳解
- Django中ORM的基本使用教程
相關(guān)文章
在Python中關(guān)于使用os模塊遍歷目錄的實(shí)現(xiàn)方法
今天小編就為大家分享一篇在Python中關(guān)于使用os模塊遍歷目錄的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
基于python實(shí)現(xiàn)銀行管理系統(tǒng)
這篇文章主要介紹了基于python實(shí)現(xiàn)銀行管理系統(tǒng),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python項(xiàng)目制作的小伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04
Python簡(jiǎn)單實(shí)現(xiàn)區(qū)域生長(zhǎng)方式
今天小編就為大家分享一篇Python簡(jiǎn)單實(shí)現(xiàn)區(qū)域生長(zhǎng)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
Python利用BeautifulSoup解析網(wǎng)頁(yè)內(nèi)容
當(dāng)今信息爆炸的時(shí)代,網(wǎng)絡(luò)上充斥著海量的數(shù)據(jù),而網(wǎng)絡(luò)爬蟲(chóng)作為一種數(shù)據(jù)采集工具,扮演著至關(guān)重要的角色,BeautifulSoup 是一個(gè)Python庫(kù),它可以從HTML或XML文件中提取數(shù)據(jù),本文介紹了Python如何利用BeautifulSoup解析網(wǎng)頁(yè)內(nèi)容,需要的朋友可以參考下2024-06-06
python雙向鏈表原理與實(shí)現(xiàn)方法詳解
這篇文章主要介紹了python雙向鏈表原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Python雙向鏈表的定義、以及節(jié)點(diǎn)的判斷、遍歷、添加、刪除等相關(guān)操作技巧,需要的朋友可以參考下2019-12-12
Python統(tǒng)計(jì)字符內(nèi)容的占比的實(shí)現(xiàn)
本文介紹了如何使用Python統(tǒng)計(jì)字符占比,包括字符串中字母、數(shù)字、空格等字符的占比,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
python偏函數(shù)的實(shí)例用法總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于python偏函數(shù)的實(shí)例用法總結(jié)內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)參考下。2021-07-07
使用python庫(kù)xlsxwriter庫(kù)來(lái)輸出各種xlsx文件的示例
這篇文章主要介紹了使用python庫(kù)xlsxwriter庫(kù)來(lái)輸出各種xlsx文件的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09

