Django:使用filter的pk進行多值查詢操作
由于想要做收藏夾的功能,所以希望能夠一次性查詢出所有id的對象,查看文檔,找到了如下方法
pk是primary key的縮寫,顧名思義pk_in就是primary key在某一個范圍內(nèi),具體操作(以自帶的User為例):
User.objects.filter(pk__in=[1,2,3])
這樣就可以去除id為1,2,3的User的對象了,很方便
注意是兩個下劃線
另外,還要pk__gt和pl_lt,都用于篩選范圍的
User.objects.filter(pk__gt=10)
意味著將要得到pk(一般也就是說id)大于10的對象(greater)
User.objects.filter(pk__lt=10)
意味著將要得到pk小于10的對象
補充知識:Django 比較同一個model中的兩個字段,進行條件過濾
django orm中怎么樣比較同一個模型中的兩個字段來過濾記錄呢?
例如一個合同字段,結(jié)束日期和終止日期的比較我們用sql很容易實現(xiàn)。
select *from contracts where
contract_stop_time<end_time
這里要是用db模塊中的F 庫才行 F object
from django.db.models import F
from contracts.models import Contracts
contracts = Contracts.objects.filter(contract_stop_time__lt=F('end_time'))
如果直接寫成
Contracts.objects.filter(contract_stop_time__lt=end_time)
或者
Contracts.objects.filter("contract_stop_time"<"end_time")
都是不行的。
以上這篇Django:使用filter的pk進行多值查詢操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- 在django中查詢獲取數(shù)據(jù),get, filter,all(),values()操作
- django filter過濾器實現(xiàn)顯示某個類型指定字段不同值方式
- 解決導入django_filters不成功問題No module named ''django_filter''
- django model 條件過濾 queryset.filter(**condtions)用法詳解
- django admin管理工具自定義時間區(qū)間篩選器DateRangeFilter介紹
- Django models filter篩選條件詳解
- django 自定義過濾器(filter)處理較為復雜的變量方法
- Django filter動態(tài)過濾與排序?qū)崿F(xiàn)過程解析
相關(guān)文章
利用Python第三方庫實現(xiàn)預測NBA比賽結(jié)果
今天給大家?guī)淼氖顷P(guān)于Python的相關(guān)知識,文章圍繞著利用Python實現(xiàn)預測NBA比賽結(jié)果展開,文中有非常詳細的介紹,需要的朋友可以參考下2021-06-06
Python英文文章詞頻統(tǒng)計(14份劍橋真題詞頻統(tǒng)計)
這篇文章主要介紹了Python英文文章詞頻統(tǒng)計(14份劍橋真題詞頻統(tǒng)計),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10
完美解決Python 2.7不能正常使用pip install的問題
今天小編就為大家分享一篇完美解決Python 2.7不能正常使用pip install的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
Python中將兩個或多個list合成一個list的方法小結(jié)
python中,list這種數(shù)據(jù)結(jié)構(gòu)很常用到,如果兩個或者多個list結(jié)構(gòu)相同,內(nèi)容類型相同,我們通常會將兩個或者多個list合并成一個,這樣我們再循環(huán)遍歷的時候就可以一次性處理掉了2019-05-05

