Django 多条件查询(Q)

本文详细介绍了在Django中使用Q对象进行复杂数据库查询的方法,包括如何使用AND、OR连接子条件,以及如何通过Q对象实现多条件组合查询。通过实际代码示例,展示了如何构建复杂的查询表达式,以便更灵活地处理数据库查询需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

from app01.models import *
from django.db.models import Q



temp = Q()
temp.connector = 'OR'
temp.children.append(('server_name__icontains','mob'))
Server.objects.filter(temp)


temp = Q()
temp.add(('server_name__icontains','mob'),'AND')
temp.add(('id',2),'AND')
temp.add(('id',3),'OR')
Server.objects.filter(temp)



__author__ = 'zhaobin022'

from django.db.models import Q
conditions = {}
values = [ 'id','name']
con = Q()
for k,v in conditions.items():
    temp = Q()
    temp.connector = 'OR'
    for item in v:
        temp.children.append((k,item))
    con.add(temp,'AND')

result = Server.objects.filter(con).values(*values)


from django.db.models import Q
con = Q()

q1 = Q()
q1.connector = 'OR'
q1.children.append(('id', 1))
q1.children.append(('id', 10))
q1.children.append(('id', 9))

q2 = Q()
q2.connector = 'OR'
q2.children.append(('c1', 1))
q2.children.append(('c1', 10))
q2.children.append(('c1', 9))

con.add(q1, 'AND')
con.add(q2, 'AND')

 

 

 

 

n [24]: temp = Q()

In [25]: temp.add(('server_name__icontains','mob'),'AND')
Out[25]: ('server_name__icontains', 'mob')

In [26]: temp.add(('id',2),'AND')
Out[26]: ('id', 2)

In [27]: Server.objects.filter(temp)
Out[27]: [<Server: cy-mobile-1>]

In [28]:

In [28]: help(temp.add)


In [29]: temp = Q()

In [30]: temp.add(('server_name__icontains','mob'),'AND')
Out[30]: ('server_name__icontains', 'mob')

In [31]: temp.add(('id',2),'AND')
Out[31]: ('id', 2)

In [32]: temp.add(('id',3),'OR')
Out[32]: ('id', 3)

In [33]: Server.objects.filter(temp)
Out[33]: [<Server: cy-mobile-1>, <Server: cy-a>]

转载于:https://www.cnblogs.com/zhaobin022/p/5059456.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值