Django中g(shù)et()和filter()返回值區(qū)別詳解
filter(**kwargs)
返回包含與給定查找參數(shù)匹配的對(duì)象的新查詢集。簡(jiǎn)單來(lái)說(shuō),返回一個(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
按照官方文檔所說(shuō)的,他是一個(gè)對(duì)象沒(méi)錯(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ì)象,可以通過(guò)student.__dict__來(lái)查看,它返回的是一個(gè)字典的形式,{’key’:valeus},key是字段的名稱,而values是值的內(nèi)容。而如果我用get方法來(lái)查詢一個(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]可以看見(jiàn)
Orders object
因此,order[0].id.也就能獲得20190003
備注: 如果filter查詢返回的結(jié)果多條,結(jié)果為
<QuerySet [<Orders:Orders object>,<Orders:Orders object>,<Orders:Orders object>]>
本質(zhì)上看起來(lái)為一個(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ì)象的列表,可以看的出來(lái)student[0]和上面的get方式返回的student的結(jié)果是一樣的。
2.2如果你用django的filter去取得關(guān)聯(lián)表的數(shù)據(jù)的話,無(wú)論關(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. idea設(shè)置自動(dòng)導(dǎo)入依賴的方法步驟2. IntelliJ IDEA配置Tomcat服務(wù)器的方法3. ASP.NET MVC把數(shù)據(jù)庫(kù)中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字4. HTML基礎(chǔ)詳解(下)5. vscode運(yùn)行php報(bào)錯(cuò)php?not?found解決辦法6. Python獲取抖音關(guān)注列表封號(hào)賬號(hào)的實(shí)現(xiàn)代碼7. WML的簡(jiǎn)單例子及編輯、測(cè)試方法第1/2頁(yè)8. CSS3實(shí)現(xiàn)動(dòng)態(tài)翻牌效果 仿百度貼吧3D翻牌一次動(dòng)畫(huà)特效9. 解決ASP中http狀態(tài)跳轉(zhuǎn)返回錯(cuò)誤頁(yè)的問(wèn)題10. ASP.NET MVC使用Session會(huì)話保持表單狀態(tài)
