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

Django中g(shù)et()和filter()返回值區(qū)別詳解

 更新時間:2021年05月12日 14:39:27   作者:溜得來  
在django中,我們查詢經(jīng)常用的兩個API中,會經(jīng)常用到get()和filter()兩個方法,兩者的區(qū)別是什么呢?本文就一起來了解一下

先上官方文檔!

filter(**kwargs)

返回包含與給定查找參數(shù)匹配的對象的新查詢集。
簡單來說,返回一個又對象組成的查詢集合

get(**kwargs)
返回與給定查找參數(shù)匹配的對象,該對象應(yīng)采用字段查找中描述的格式。

例子

例如在Model中有一個Order類,包含一個id字段,輸入 id 為2019 字段的 id

1.get()方法

orders = Orders.objects.get(id=20190003)
print(order)

先查看orders是什么,結(jié)果為

Orders object

按照官方文檔所說的,他是一個對象沒錯,可以直接用點(diǎn)操作進(jìn)行字段取值

print(order.id)

結(jié)果就是20190003

 1.1 django的get方法是從數(shù)據(jù)庫的取得一個匹配的結(jié)果,返回一個對象,如果記錄不存在的話,它會報(bào)錯。

比如我數(shù)據(jù)庫里有一條記錄,記錄的name的值是” 老王python”的話,我用student= Student.objects.get(name='老王python'),返回的是一個記錄對象,可以通過student.__dict__來查看,它返回的是一個字典的形式,{'key':valeus},key是字段的名稱,而values是值的內(nèi)容。而如果我用get方法來查詢一個數(shù)據(jù)庫里不存在的記錄,程序會報(bào)錯。比如:student = Student.objects.get(name='老王')。

1.2如果用django的get去取得關(guān)聯(lián)表的數(shù)據(jù)的話,而關(guān)鍵表的數(shù)據(jù)如果多于2條的話也會報(bào)錯。

2.filter() 方法

orders = Orders.objects.filter(id=20190003)
print(order)

先查看orders是什么

<QuerySet [<Orders:Orders object>]>

我認(rèn)為 前面的QuerySet 是告訴我們這個是一個查詢集,真正的查詢集內(nèi)容是列表[]里面的東西,<>表示查詢集的范圍。[]中的Orders同理。這個時候我們發(fā)現(xiàn)[]中的東西就是get()方法所獲得東西,因此只需要取order[0]即可,打印order[0]可以看見

Orders object

因此,order[0].id.也就能獲得20190003

備注: 如果filter查詢返回的結(jié)果多條,結(jié)果為

<QuerySet [<Orders:Orders object>,<Orders:Orders object>,<Orders:Orders object>]>

本質(zhì)上看起來為一個列表

補(bǔ)充: 2.1 django的filter方法是從數(shù)據(jù)庫的取得匹配的結(jié)果,返回一個對象列表,如果記錄不存在的話,它會返回[]。

比如我數(shù)據(jù)庫里有一條記錄,記錄的name的值是老王python的話,我用student = Student.objects.filter(name='老王python'),它返回的student是一個對象的列表,可以看的出來student[0]和上面的get方式返回的student的結(jié)果是一樣的。

2.2如果你用django的filter去取得關(guān)聯(lián)表的數(shù)據(jù)的話,無論關(guān)聯(lián)表有多少記錄的都不會報(bào)錯。

另外我從別的資料里看到filter好像有緩存數(shù)據(jù)的功能,第一次查詢數(shù)據(jù)庫并生成緩存,下次再調(diào)用filter方法的話,直接取得緩存的數(shù)據(jù),會get方法每次執(zhí)行都是直接查詢數(shù)據(jù)庫的,不知道這個是不是正確。

總結(jié):

get()返回的是一個對象,filter()返回的是由對象組成的列表,稱為查詢集

到此這篇關(guān)于Django中g(shù)et()和filter()返回值區(qū)別詳解的文章就介紹到這了,更多相關(guān)Django get()和filter()返回值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python數(shù)據(jù)結(jié)構(gòu)樹與算法分析

    Python數(shù)據(jù)結(jié)構(gòu)樹與算法分析

    這篇文章主要介紹了Python數(shù)據(jù)結(jié)構(gòu)樹與算法分析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • Django如何實(shí)現(xiàn)密碼錯誤報(bào)錯提醒

    Django如何實(shí)現(xiàn)密碼錯誤報(bào)錯提醒

    這篇文章主要介紹了Django如何實(shí)現(xiàn)密碼錯誤報(bào)錯提醒,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值
    2020-09-09
  • 詳解字典樹Trie結(jié)構(gòu)及其Python代碼實(shí)現(xiàn)

    詳解字典樹Trie結(jié)構(gòu)及其Python代碼實(shí)現(xiàn)

    Trie多被用來查找和統(tǒng)計(jì)字符串,利用公共前綴來減少搜索時間,下面我們就來詳解字典樹Trie結(jié)構(gòu)及其Python代碼實(shí)現(xiàn)
    2016-06-06
  • Opencv+Python識別PCB板圖片的步驟

    Opencv+Python識別PCB板圖片的步驟

    這篇文章主要介紹了Opencv+Python識別PCB板圖片的步驟,幫助大家更好的理解和使用python進(jìn)行機(jī)器學(xué)習(xí),感興趣的朋友可以了解下
    2021-01-01
  • Django進(jìn)階深入理解使用類視圖和中間件示例

    Django進(jìn)階深入理解使用類視圖和中間件示例

    這篇文章主要為大家介紹了Django高級指南之深入理解和使用類視圖和中間件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • python?skimage圖像處理

    python?skimage圖像處理

    這篇文章主要為大家介紹了python?skimage圖像處理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 使用Python自動化創(chuàng)建和掃描二維碼

    使用Python自動化創(chuàng)建和掃描二維碼

    二維碼(Quick Response code)已成為在物理和數(shù)字領(lǐng)域之間架起橋梁的多功能工具,從分享聯(lián)系信息和網(wǎng)站鏈接到促進(jìn)支付和跟蹤庫存,二維碼在各個行業(yè)中找到了應(yīng)用,本文將展示如何使用Python自動化創(chuàng)建和掃描二維碼,感興趣的朋友可以參考下
    2024-07-07
  • Python處理MySQL與SQLite數(shù)據(jù)庫詳解

    Python處理MySQL與SQLite數(shù)據(jù)庫詳解

    在數(shù)據(jù)處理和存儲方面,數(shù)據(jù)庫扮演著至關(guān)重要的角色,Python提供了多種與數(shù)據(jù)庫交互的方式,本文主要介紹了如何對MySQL與SQLite數(shù)據(jù)庫進(jìn)行增刪改查操作,需要的可以了解下
    2025-02-02
  • Python作用域與名字空間源碼學(xué)習(xí)筆記

    Python作用域與名字空間源碼學(xué)習(xí)筆記

    這篇文章主要為大家介紹了Python作用域與名字空間的源碼學(xué)習(xí)筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2022-05-05
  • python 基于TCP協(xié)議的套接字編程詳解

    python 基于TCP協(xié)議的套接字編程詳解

    這篇文章主要介紹了python 基于TCP協(xié)議的套接字編程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-06-06

最新評論