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

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

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

先上官方文檔!

filter(**kwargs)

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

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

例子

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

1.get()方法

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

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

Orders object

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

print(order.id)

結(jié)果就是20190003

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

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

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

2.filter() 方法

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

先查看orders是什么

<QuerySet [<Orders:Orders object>]>

我認(rèn)為 前面的QuerySet 是告訴我們這個(gè)是一個(gè)查詢集,真正的查詢集內(nèi)容是列表[]里面的東西,<>表示查詢集的范圍。[]中的Orders同理。這個(gè)時(shí)候我們發(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ì)上看起來為一個(gè)列表

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

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

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

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

總結(jié):

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

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

相關(guān)文章

  • python 猴子補(bǔ)丁(monkey patch)

    python 猴子補(bǔ)丁(monkey patch)

    這篇文章主要介紹了python 猴子補(bǔ)丁(monkey patch),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)實(shí)現(xiàn)查找兩個(gè)字典相同點(diǎn)的方法

    Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)實(shí)現(xiàn)查找兩個(gè)字典相同點(diǎn)的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)查找兩個(gè)字典相同點(diǎn)的方法,涉及Python常見集合運(yùn)算操作技巧,需要的朋友可以參考下
    2018-02-02
  • python pandas dataframe 行列選擇,切片操作方法

    python pandas dataframe 行列選擇,切片操作方法

    下面小編就為大家分享一篇python pandas dataframe 行列選擇,切片操作方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • Python的Random庫(kù)的使用方法詳解

    Python的Random庫(kù)的使用方法詳解

    這篇文章主要介紹了Python的Random庫(kù)的使用方法詳解,random庫(kù)是使用隨機(jī)數(shù)的Python標(biāo)準(zhǔn)庫(kù),python中用于生成偽隨機(jī)數(shù)的函數(shù)庫(kù)是random,需要的朋友可以參考下
    2023-07-07
  • Python中reduce函數(shù)詳解

    Python中reduce函數(shù)詳解

    本文主要介紹了Python中reduce函數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Python編寫百度貼吧的簡(jiǎn)單爬蟲

    Python編寫百度貼吧的簡(jiǎn)單爬蟲

    這篇文章主要介紹了Python編寫百度貼吧的簡(jiǎn)單爬蟲,簡(jiǎn)單實(shí)現(xiàn)了下載對(duì)應(yīng)頁(yè)碼的頁(yè)面并存為以當(dāng)前時(shí)間命名的html文件,這里分享給大家,拋磚引玉。
    2015-04-04
  • 解決pycharm 工具欄Tool中找不到Run manager.py Task的問題

    解決pycharm 工具欄Tool中找不到Run manager.py Task的問題

    今天小編就為大家分享一篇解決pycharm 工具欄Tool中找不到Run manager.py Task的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python中判斷語(yǔ)句入門指南(if?elif?else語(yǔ)句)

    Python中判斷語(yǔ)句入門指南(if?elif?else語(yǔ)句)

    if elif else語(yǔ)句是Python中的控制語(yǔ)句,用于根據(jù)條件執(zhí)行不同的操作,下面這篇文章主要給大家介紹了關(guān)于Python中判斷語(yǔ)句入門指南(if?elif?else語(yǔ)句)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 打包PyQt5應(yīng)用時(shí)的注意事項(xiàng)

    打包PyQt5應(yīng)用時(shí)的注意事項(xiàng)

    這篇文章主要介紹了打包PyQt5應(yīng)用時(shí)的注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下
    2020-02-02
  • django多個(gè)APP的urls設(shè)置方法(views重復(fù)問題解決)

    django多個(gè)APP的urls設(shè)置方法(views重復(fù)問題解決)

    今天小編就為大家分享一篇django多個(gè)APP的urls設(shè)置方法(views重復(fù)問題解決),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07

最新評(píng)論