Django:使用filter的pk進(jìn)行多值查詢操作
由于想要做收藏夾的功能,所以希望能夠一次性查詢出所有id的對(duì)象,查看文檔,找到了如下方法
pk是primary key的縮寫,顧名思義pk_in就是primary key在某一個(gè)范圍內(nèi),具體操作(以自帶的User為例):
User.objects.filter(pk__in=[1,2,3])
這樣就可以去除id為1,2,3的User的對(duì)象了,很方便
注意是兩個(gè)下劃線
另外,還要pk__gt和pl_lt,都用于篩選范圍的
User.objects.filter(pk__gt=10)
意味著將要得到pk(一般也就是說id)大于10的對(duì)象(greater)
User.objects.filter(pk__lt=10)
意味著將要得到pk小于10的對(duì)象
補(bǔ)充知識(shí):Django 比較同一個(gè)model中的兩個(gè)字段,進(jìn)行條件過濾
django orm中怎么樣比較同一個(gè)模型中的兩個(gè)字段來過濾記錄呢?
例如一個(gè)合同字段,結(jié)束日期和終止日期的比較我們用sql很容易實(shí)現(xiàn)。
select *from contracts where
contract_stop_time<end_time
這里要是用db模塊中的F 庫才行 F object
from django.db.models import Ffrom contracts.models import Contractscontracts = 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進(jìn)行多值查詢操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. jsp文件下載功能實(shí)現(xiàn)代碼2. jsp實(shí)現(xiàn)登錄驗(yàn)證的過濾器3. 如何在jsp界面中插入圖片4. ASP動(dòng)態(tài)網(wǎng)頁制作技術(shù)經(jīng)驗(yàn)分享5. 詳解瀏覽器的緩存機(jī)制6. .Net Core和RabbitMQ限制循環(huán)消費(fèi)的方法7. Xml簡(jiǎn)介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理8. phpstudy apache開啟ssi使用詳解9. JSP之表單提交get和post的區(qū)別詳解及實(shí)例10. .Net加密神器Eazfuscator.NET?2023.2?最新版使用教程
