您好,登錄后才能下訂單哦!
這篇“Django中get()和filter()返回值有什么區別”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Django中get()和filter()返回值有什么區別”文章吧。
filter(**kwargs)
返回包含與給定查找參數匹配的對象的新查詢集。
簡單來說,返回一個又對象組成的查詢集合
get(**kwargs)
返回與給定查找參數匹配的對象,該對象應采用字段查找中描述的格式。
例子
例如在Model中有一個Order類,包含一個id字段,輸入 id 為2019 字段的 id
orders = Orders.objects.get(id=20190003)
print(order)
先查看orders是什么,結果為
Orders object
按照官方文檔所說的,他是一個對象沒錯,可以直接用點操作進行字段取值
print(order.id)
結果就是20190003
1.1 django的get方法是從數據庫的取得一個匹配的結果,返回一個對象,如果記錄不存在的話,它會報錯。
比如我數據庫里有一條記錄,記錄的name的值是” 老王python”的話,我用student= Student.objects.get(name='老王python'),返回的是一個記錄對象,可以通過student.__dict__來查看,它返回的是一個字典的形式,{'key':valeus},key是字段的名稱,而values是值的內容。而如果我用get方法來查詢一個數據庫里不存在的記錄,程序會報錯。比如:student = Student.objects.get(name='老王')。
1.2如果用django的get去取得關聯表的數據的話,而關鍵表的數據如果多于2條的話也會報錯。
orders = Orders.objects.filter(id=20190003)
print(order)
先查看orders是什么
<QuerySet [<Orders:Orders object>]>
我認為 前面的QuerySet 是告訴我們這個是一個查詢集,真正的查詢集內容是列表[]里面的東西,<>表示查詢集的范圍。[]中的Orders同理。這個時候我們發現[]中的東西就是get()方法所獲得東西,因此只需要取order[0]即可,打印order[0]可以看見
Orders object
因此,order[0].id.也就能獲得20190003
備注: 如果filter查詢返回的結果多條,結果為
<QuerySet [<Orders:Orders object>,<Orders:Orders object>,<Orders:Orders object>]>
本質上看起來為一個列表
補充: 2.1 django的filter方法是從數據庫的取得匹配的結果,返回一個對象列表,如果記錄不存在的話,它會返回[]。
比如我數據庫里有一條記錄,記錄的name的值是老王python的話,我用student = Student.objects.filter(name='老王python'),它返回的student是一個對象的列表,可以看的出來student[0]和上面的get方式返回的student的結果是一樣的。
2.2如果你用django的filter去取得關聯表的數據的話,無論關聯表有多少記錄的都不會報錯。
另外我從別的資料里看到filter好像有緩存數據的功能,第一次查詢數據庫并生成緩存,下次再調用filter方法的話,直接取得緩存的數據,會get方法每次執行都是直接查詢數據庫的,不知道這個是不是正確。
以上就是關于“Django中get()和filter()返回值有什么區別”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。