Django?ORM?F對(duì)象和Q對(duì)象查詢
閱讀文本前請(qǐng)參考此文章的數(shù)據(jù)表結(jié)構(gòu)
Django提供了兩個(gè)非常有用的工具:F對(duì)象和Q對(duì)象,方便了在一些特殊場(chǎng)景下的查詢過(guò)程。
1.F對(duì)象查詢
F對(duì)象用于操作數(shù)據(jù)庫(kù)中某一列的值,它可以在沒(méi)有實(shí)際訪問(wèn)數(shù)據(jù)庫(kù)獲取數(shù)據(jù)值的情況下對(duì)字段的值進(jìn)行引用
使用F對(duì)象之前需要將它引入當(dāng)前的環(huán)境中:
from django.db.models import F
如果要查詢up小于等于down的Comment:
comment = Comment.objects.filter(up__lte=F('down'))
要查詢所有up值大于down值2倍的Comment對(duì)象,可以這樣實(shí)現(xiàn):
comment = Comment.objects.filter(up__gt=F('down') * 2)
使用F查詢讓表中的某個(gè)字段值+1:
comment = Comment.objects.get(id=1) comment.up = F('up') + 1 comment.save()
2.Q對(duì)象查詢
使用Q對(duì)象之前需要將它引入當(dāng)前的環(huán)境中:
from django.db.models import Q
如果想要查詢up大于60或down大于60的所有Comment對(duì)象:
comment = Comment.objects.filter(Q(up__gt=60) | Q(down__gt=60))
Q對(duì)象也可以與關(guān)鍵字參數(shù)組合在一起使用,但是在這種情況下,Django規(guī)定,Q對(duì)象必須放在前面:
多個(gè)Q對(duì)象可以使用“
&
”(與)、“|
”(或)運(yùn)算符組合,產(chǎn)生一個(gè)新的Q對(duì)象??梢允褂?ldquo;~
”(非)運(yùn)算符取反,即實(shí)現(xiàn)NOT查詢??
到此這篇關(guān)于Django ORM F對(duì)象和Q對(duì)象查詢的文章就介紹到這了,更多相關(guān)Django F對(duì)象和Q對(duì)象查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)檢測(cè)文件MD5值的方法示例
這篇文章主要介紹了Python實(shí)現(xiàn)檢測(cè)文件MD5值的方法,涉及Python針對(duì)大文件的讀取、判斷、運(yùn)算、加密等相關(guān)操作技巧,需要的朋友可以參考下2018-04-04python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法
今天小編就為大家分享一篇python 對(duì)dataframe下面的值進(jìn)行大規(guī)模賦值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Python調(diào)用SQLPlus來(lái)操作和解析Oracle數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了Python調(diào)用SQLPlus來(lái)操作和解析Oracle數(shù)據(jù)庫(kù)的方法,這樣用SQL*Plus方式來(lái)分析Oracle中的數(shù)據(jù)就變得十分方便,需要的朋友可以參考下2016-04-04Python中json.dumps()函數(shù)的使用解析
json.dumps將一個(gè)Python數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)換為JSON,本文介紹了Python中json.dumps()函數(shù)的具體使用方法,以及和dump的區(qū)別,感興趣的可以了解一下2021-05-05Python+Empyrical實(shí)現(xiàn)計(jì)算風(fēng)險(xiǎn)指標(biāo)
Empyrical 是一個(gè)知名的金融風(fēng)險(xiǎn)指標(biāo)庫(kù)。它能夠用于計(jì)算年平均回報(bào)、最大回撤、Alpha值等。下面就教你如何使用 Empyrical 這個(gè)風(fēng)險(xiǎn)指標(biāo)計(jì)算神器2022-05-05關(guān)于tensorflow中tf.keras.models.Sequential()的用法
這篇文章主要介紹了關(guān)于tensorflow中tf.keras.models.Sequential()的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01