1. 程式人生 > 程式設計 >Python Django2 model 查詢介紹(條件、範圍、模糊查詢)

Python Django2 model 查詢介紹(條件、範圍、模糊查詢)

條件查詢

範圍查詢

模糊查詢

條件查詢

all()

返回全部結果集

filter(**kwargs)

返回滿足引數定義的結果集 例如

Entry.objects.filter(pub_date__year=2006)

exclude(**kwargs)

返回不滿足引數定義的結果集 例如

Entry.objects.exclude(pub_date__year=2006)

鏈式查詢

Entry.objects.filter(... 
  headline__startswith='What'... )
.exclude(...
   pub_date__gte=datetime.date.today()... )
.filter(...
   pub_date__gte=datetime.date(2005,1,30)... )

也可以這樣

q1 = Entry.objects.filter(headline__startswith="What")
q2 = q1.exclude(pub_date__gte=datetime.date.today())
q3 = q1.filter(pub_date__gte=datetime.date.today())

或者

q = Entry.objects.filter(headline__startswith="What")
q = q.filter(pub_date__lte=datetime.date.today())
q = q.exclude(body_text__icontains="food")
get()

filter()返回的是一個結果集,如果你確定你要返回的是一條結果,那麼就可以使用get() 例如

Entry.objects.get(pk=1)

get()與filter()區別

get()返回單一的一條記錄,返回型別也是一個物件,filter()返回的實際一個結果集,返回型別為列表。
使用get(),如果查詢結果為空,將會引起DoesNotExist exception,而filter()將會返回[]

範圍查詢

Limiting
Entry.objects.all()[:5]

將會返回前5條記錄

Entry.objects.all()[5:10]

將會返回5~10條記錄

order_by

排序

Entry.objects.order_by('headline')[0]

將會按照'headline'進行排序,然後返回第一條記錄

語法:欄位 + 兩條下劃線 + 內建查詢欄位

lt(lte): 小於(小於等於)

Entry.objects.filter(pub_date__lte='2006-01-01')

等同於

SELECT * FROM ... WHERE pub_date <= '2006-01-01';

gt(gte): 大於(大於等於)

in

Entry.objects.filter(id__in=[1,3])

模糊查詢

range

常用來篩選出屬於某個連續區間的物件

Entry.objects.filter(id__range=[1,3])
contains 

包含‘xxx'(大小寫敏感),常用於找出包含某些關鍵字的物件

Entry.objects.filter(type__name__contains='python')

等同於

SELECT ... WHERE name LIKE '%python%';

類似的有icontains (大小寫不敏感)。注意contains是大小寫敏感的,icontains是大小寫不敏感的。

startswith

以‘xxx'開頭(大小寫敏感)

Entry.objects.filter(name__startswith='高階')

等同於

SELECT ... WHERE name LIKE '高階%';

類似的有istartswith (大小寫不敏感)

endswith

以‘xxx'結尾(大小寫敏感)

類似的有iendswith (大小寫不敏感)

isnull

可設定為True或者False,用來篩選某欄位 為NULL / 不為NULL 的物件

Entry.objects.filter(description__isnull=True)

等同

SELECT ... WHERE description IS NULL;

補充知識:Django filter **conditions多條件多欄位過濾篩選資料

Application context 應用場景:

新增的一條資料不能與DB庫裡有的資料重複或者需要多條件/多欄位篩選資料時需要用到 **conditions

conditions ={
  'server_ip': ip,"bk_biz_id": bk_biz_id,'cron_min': c["cron_min"],'cron_hour': c["cron_hour"],'cron_day': c["cron_day"],'cron_month': c["cron_month"],'cron_week': c["cron_week"],'cron_task': c["cron_task"],"creator": c["user"],"deleted": 0
}
query_set = CrontabInfo.objects.filter(**conditions)

以上這篇Python Django2 model 查詢介紹(條件、範圍、模糊查詢)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。