django model filter查询

本文深入探讨了成为一名成功的架构师所需的关键技能,并详细解析了多表连接查询、反向查询及复杂条件选取等数据库操作技巧。通过实例演示,帮助读者掌握高效查询方法,为晋升架构师打下坚实基础。

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

1.多表连接查询:

class A(models.Model):
    name = models.CharField(u'姓名')
class B(models.Model):
    aa = models.ForeignKey(A)
B.objects.filter(aa__name__contains='searchtitle')


2.反向查询:

class A(models.Model):
    name = models.CharField(u'姓名')
class B(models.Model):
    aa = models.ForeignKey(A,related_name="NM")    
bb = models.CharField(u'名称')

查A: A.objects.filter(NM__bb='XXXX'),都知道related_name的作用,A.NM.all()是一组以A为外键的 B实例,可前面这样的用法是查询出所有(B.aa=A且B.bb=XXXX)的A实例,然后还可以通过__各种关系查找。


3.条件选取querySet的时候,filter表示=,exclude表示!=。

querySet.distinct()    去重复

__exact    精确等于 like 'aa'

__iexact    精确等于,忽略大小写 ilike 'aa'

__contains    包含 like '%aa%'

__icontains    包含,忽略大小写 ilike '%aa%',但是对于sqlite来说,contains的作用效果等同与icontains。

__gt    大于

__dte    大于等于

__lt    小于

__lte    小于等于

__in    存在于一个list范围内

__startwith    以...开头

__istartwith    以...开头,忽略大小写

__endswith    以...结尾

__iendswith    以...结尾,忽略大小写

__range    在...范围内

__year    日期字段的年份

__month    日期字段的月份 

__day    日期字段的日

__isnull=True/False


例子:

q1 = Entry.objects.filter(headline__startswith="My")
q2 = q1.exclude(pub_date__gte=datetime.date.today())
q3 = q1.filter(pub_date__gte=datetime.date.today())
q = q.filter(pub_date__lte=datetime.date.today())
q = q.exclude(body_text__icontains="food")

q1.filter(pub_date__gte=datetime.date.today())表示为时间>=now

q1.exclude(pub_date__gte=datetime.date.today())表示为<=now


关于缓存:
queryset是有缓存的,a = A.objects.all(),print [i for i in a].第一次执行打印会查询数据库,然后结果会被保存在queryset内置的cache中,再执行print的时候就会取自缓存。很多时候会遇到仅需判断queryset是否为空的情况,可以1. if queryset:pass 2.if queryset.count>0:pass 3.if queryset.exists():pass. 三种方式性能依次提升。当queryset非常巨大时,cache会成为问题。此时可以queryset.iterator(),迭代器的用处就不多说了,根据具体需求情况使用。


转载于:https://my.oschina.net/chqi/blog/388034

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值