首頁>技術>

我們在使用Django的 models 查詢資料庫時,可以看到有這種寫法:

在這種寫法裡面,query物件有一個filter方法,這個方法的返回資料還可以繼續呼叫filter方法,可以這樣無限制地呼叫下去。

這種寫法是怎麼實現的呢?

如果我們直接寫一個類的方法,看看能不能這樣呼叫:

直接對query.filter()返回的結果再呼叫一次filter,就會導致報錯了。這是因為在沒有顯式寫return語句的時候,方法會返回None,而None物件是沒有所謂的filter方法的。

那麼什麼東西有filter方法呢?顯然我們的query物件有filter方法。那麼如何讓這個方法返回自身這個物件呢?

這個時候,我們就要看看我們在定義類方法的時候,總會寫的的第一個引數self了。幾乎每個類方法裡面都會有它。大家只知道在類裡面呼叫類方法的時候可以用self.xxx(),在呼叫類屬性的時候可以用self.yy,那麼有沒有思考過,這個東西如果單獨使用會怎麼樣呢?

實際上,self指的就是這個類例項化成一個物件以後,這個物件自身。而這個物件顯然是有filter方法的。所以我們修改一下filter方法,讓它返回self:

從圖中可以看出,現在已經不會報錯了。那麼回到最開始的問題,Django裡面的鏈式呼叫傳入查詢引數是如何實現的呢?

實際上這裡涉及到一個惰性查詢的問題。

當我們不停呼叫.filter()方法的時候,Django會把這些查詢條件全部 快取 起來,只有當我們需要獲取結果,或者查詢滿足條件的資料有多少條時,它才會真正地連線資料庫去查詢。

所以我們這裡要模擬這個環境,把查詢條件快取起來。

那麼為了獲取呼叫方法時傳入的引數名,我們就要使用**kwargs引數。這個引數可以接受所有的key=value形式的引數:

執行效果如下圖所示:

在真正需要輸出結果的時候,再使用這些快取的條件,去資料庫中查詢結果即可。

10
最新評論
  • BSA-TRITC(10mg/ml) TRITC-BSA 牛血清白蛋白改性標記羅丹明
  • 聊聊Python自動化指令碼部署伺服器全流程(詳細)