欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談django orm 優(yōu)化

 更新時間:2018年08月18日 17:15:21   作者:banananana  
這篇文章主要介紹了淺談django orm 優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

orm優(yōu)化

1.數(shù)據(jù)庫技術進行優(yōu)化,包括給字段加索引,設置唯一性約束等等;

2.查詢過濾工作在數(shù)據(jù)庫語句中做,不要放在代碼中完成(看情況);

3.如果要一次查詢出集合的數(shù)量,使用count函數(shù),而不是len函數(shù),但是如果后面還需要到集合,那就用len,因為count還需要進行一次數(shù)據(jù)庫的操作;

4.避免過多的使用count和exists函數(shù);

5.如果需要查詢對象的外鍵,則使用外鍵字段而不是使用關聯(lián)的外鍵的對象的主鍵;

例子:

a.b_id # 正確
a.b.id # 錯誤

6.在通過all語句查詢時,不要做跨表查詢,只查詢當前表中有的數(shù)據(jù),否則查詢語句的性能會下降很多;

 比如:a表存在外鍵b表

a.b.all() # 錯誤

7.如果想要查詢其他表的數(shù)據(jù),則加上select_related(ForeignKey字段名,其實就是主動聯(lián)表查詢,性能也會下降),如果有多個,則在括號中加上;

8.加only參數(shù)是從查詢結果中只取某個字段,而另外一個defer方法則是從查詢結果中排除某個字段;

9.不要獲取你不需要的東西,可以通過values和value_list實現(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.如果想知道是否存在至少一個結果,使用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()都會導致額外的查詢;

12.不要做無所謂的排序,排序并非沒有代價,每個排序的字段都是數(shù)據(jù)庫必須執(zhí)行的操作;

13.如果要插入多條數(shù)據(jù),則使用bulk_create來批量插入,減少sql查詢的數(shù)量;

14.對于緩存的QuerySet對象使用with標簽,可以讓數(shù)據(jù)被緩存起來使用;

15.使用QuerySet.extra明確的指出要查詢的字段;

16.批量的更新和刪除則使用Queryset.update和delete函數(shù),但是更新操作注意對象的緩存;

17.使用QuerySet.Iterator迭代大數(shù)據(jù); 

當你獲得一個queryset的時候,django會緩存下來,保存在內存中,如果需要對queryset進行多次的循環(huán),那么這種緩存無可厚非; 但是如果你只需要進行一次的循環(huán),那么其實并不需要緩存,這個使用就可以使用iterator;

比如:

for book in Books.objects.all().iterator():
  do_stuff(book)

18.如果想判斷是否存在外鍵,只需要判斷外鍵的id即可;

19.不要在循環(huán)中查詢,而是提前取出,并且做好映射關系,這樣在循環(huán)中直接通過字典的形式獲取到;

20.當計算出一個QuerySet的時候,如果還需要進行多次循環(huán)的話,則可以先保留著這個緩存,但是如果只是使用一次的話,沒有必要使用到緩存; 

python優(yōu)化:

1.排序盡量使用 .sort(), 其中使用 key 比 cmp 效率更高

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Python實現(xiàn)的最近最少使用算法

    Python實現(xiàn)的最近最少使用算法

    這篇文章主要介紹了Python實現(xiàn)的最近最少使用算法,涉及節(jié)點、時間、流程控制等相關技巧,需要的朋友可以參考下
    2015-07-07
  • python給圖像加上mask,并提取mask區(qū)域實例

    python給圖像加上mask,并提取mask區(qū)域實例

    今天小編就為大家分享一篇python給圖像加上mask,并提取mask區(qū)域實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python入門篇之編程習慣與特點

    Python入門篇之編程習慣與特點

    本文是Python入門篇的第一篇文章,主要講述了Python編程習慣和特點等一些基礎知識,有需要的朋友可以參考下
    2014-10-10
  • Python selenium如何設置等待時間

    Python selenium如何設置等待時間

    這篇文章主要為大家詳細介紹了Python selenium如何設置等待時間,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Python爬蟲設置代理IP的方法(爬蟲技巧)

    Python爬蟲設置代理IP的方法(爬蟲技巧)

    這篇文章主要介紹了Python爬蟲設置代理IP的方法(爬蟲技巧),需要的朋友可以參考下
    2018-03-03
  • Python制作exe文件簡單流程

    Python制作exe文件簡單流程

    在本篇文章里我們給大家分享了關于Python制作exe文件的相關知識點內容,有需要的朋友們學習下。
    2019-01-01
  • Python 列表推導式與字典推導式的實現(xiàn)

    Python 列表推導式與字典推導式的實現(xiàn)

    本文主要介紹了Python 列表推導式與字典推導式的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Python面試之os.system()和os.popen()的區(qū)別詳析

    Python面試之os.system()和os.popen()的區(qū)別詳析

    Python調用Shell,有兩種方法:os.system(cmd)或os.popen(cmd)腳本執(zhí)行過程中的輸出內容,下面這篇文章主要給大家介紹了關于Python面試之os.system()和os.popen()區(qū)別的相關資料,需要的朋友可以參考下
    2022-06-06
  • Django路由Path方法的實現(xiàn)

    Django路由Path方法的實現(xiàn)

    本文主要介紹了Django路由Path方法的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • python-str,list,set間的轉換實例

    python-str,list,set間的轉換實例

    今天小編就為大家分享一篇python-str,list,set間的轉換實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06

最新評論