django filter查询多选_Django------filter查询的使用

本文详细介绍了Django中filter查询的使用,包括`__contains`、`__in`、`__range`等操作符的用法,以及如何进行不包含查询、日期类型的查询和排序。同时,还展示了如何通过dates方法处理日期查询结果,并提供了代码示例来展示如何在前端显示这些查询结果。
摘要由CSDN通过智能技术生成

一:filter查询可以方便的查询出我们需要使用的信息:

defblogdetail(request,aricle_id):

contenx={}

detail= contenx['detail'] = get_object_or_404(Blog,pk =aricle_id)

contenx['blog_previous'] = Blog.objects.filter(create_time__gt = detail.create_time).last()#得到上一页信息

contenx['blog_next'] = Blog.objects.filter(create_time__lt = detail.create_time).first()#下一页信息

contenx['detail'] =detailreturn render_to_response('blog/detail.html',contenx)

一、下面来看看:filter查询:

1.__contains(包含)

shell命令下查询:Blog.objects.filter(title__contains ="django")------------------>返回一个queryset[]查询(查询集)只能输入一个值。加上一个"i"后不区别大小写【sql等数据库中】

2.__in (其中之一,可以传入一个列表,传多个值。)

Blog.objects.filter(id__in = [3,6,9])

3.__range(一个范围,使用元祖):

> Blog.objects.filter(id__range =(30,45))

二、前面讲的是包含的查询,下面来看看不包含的查询:

exclude方法为不包含的:

Blog.objects.exclude(id=3)

三、日期类型查询

Blog.objects.filter(create_time__year = 2018)------------->查询年为2018年的内容

Blog.objects.filter(create_time__month=3)----------------->查询月

四、日期查询类型只是筛选了条件,怎么让条件在前端显示呢?django提供了一个dates方法:

Blog.objects.dates('create_time', 'year','DESC')--------------------->分别为:时间字段,查询返回年year,年月month,年月日day,最后一个参数是排序方式ASC正序,DESC倒序。

defblog_with_date(request,year,month):

contenx={}

blogs= Blog.objects.filter(create_time__year = year ,create_time__month =month)

paginator= Paginator(blogs, settings.EACH_OF_BLOGS_NUMBER)#每10篇文章分一页

page_num = request.GET.get('page',1)#GET方法获得url参数?page1 page是参数需要带引号

page_of_blogs = paginator.get_page(page_num)#get_page方法处理用户输入的错误值

current_page_num = page_of_blogs.number#获得当前页

#比较截取到想要的那个数到最小值1时用小的值和1作比较生成一个从小到当前的值

range_page = list(range(max(current_page_num-2,1),curr

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Django提供了多种方法来进行多条件过滤。 一种方法是使用Q对象来构建复杂的查询条件。Q对象允许你使用"&"(与),"|"(或)和"~"(非)来构建复杂的查询表达式。例如: ``` from django.db.models import Q MyModel.objects.filter(Q(field1='value1') | Q(field2='value2')) ``` 另一种方法是使用连锁的过滤器,例如: ``` MyModel.objects.filter(field1='value1').filter(field2='value2') ``` 还可以使用 "__in" 和 "__range" 等运算符来进行多条件过滤。 ``` MyModel.objects.filter(field1__in=['value1','value2'], field2__range=[start_date, end_date]) ``` 总之,Django提供了很多种方法来进行多条件过滤,应该根据实际需求来选择使用哪种方法。 ### 回答2: Django filter多条件过滤主要是指在查询数据时,需要使用多个条件来过滤数据。这些条件可以使用“and”、“or”等逻辑运算符进行组合,从而实现更加精准且灵活的数据查询。 在Django中,使用filter()方法来实现多条件过滤。filter()方法接受一系列的参数,每个参数都代表一个条件,这些条件之间可以使用逗号或者“&”、“|”等逻辑运算符连接。例如,我们可以按如下方式查询符合多个条件的数据: `from myapp.models import MyModel` `results = MyModel.objects.filter(condition1=value1, condition2=value2, ...)` 在这个例子中,我们通过调用filter()方法获取了一个查询集对象results,其中包含满足所有条件的数据。参数condition1、condition2等都是数据表中的字段,value1、value2等则是对应的值。多个参数之间使用逗号或逻辑运算符组合,表示这些条件之间的关系。 如果我们需要使用“or”等逻辑运算符进行组合,可以使用Q对象来实现。Q对象可以实现更为灵活的复杂查询,它可以被组合成更复杂的查询条件,以便达到更高效的查询结果。例如,我们可以按如下方式查询符合多个条件的数据: `from django.db.models import Q` `from myapp.models import MyModel` `my_filter = Q(condition1=value1) | Q(condition2=value2) | Q(...)` `results = MyModel.objects.filter(my_filter)` 在这个例子中,我们使用Q对象创建了一个包含多个条件的查询过滤器。使用“|”符号将每个查询条件连接起来,表示这些条件之间的关系。在应用过滤器时,我们只需要将查询过滤器作为参数传递给filter()方法即可。 总之,使用Django filter多条件过滤可以让我们更加精准地查询数据。通过灵活使用逗号、逻辑运算符和Q对象,我们可以组合多个查询条件,并自由地调整它们之间的关系,以便得到符合要求的数据。 ### 回答3: Django filter多条件过滤是指,在Django使用filter()函数进行多个条件的数据筛选。在Django的模型中,我们通常会定义一些字段,如title、content、created_at等,而使用filter()函数可以实现多条件过滤,如where条件的联合查询。 在Django中,我们通常使用__符号来连接字段和过滤器的名称,如: ``` from django.db import models class Article(models.Model): title = models.CharField(max_length=100) content = models.TextField() created_at = models.DateTimeField(auto_now_add=True) def __str__(self): return self.title ``` 在上述模型中,我们定义了三个字段:title、content和created_at,我们可以使用__符号来进行多条件查询,如: ``` Article.objects.filter(title__contains='Django', content__icontains='filter', created_at__year=2020) ``` 上述代码将会筛选出所有标题中包含'Django'、 内容中包含'filter'、 并且创建时间在2020年的文章。 其中,__contains和__icontains可以用来匹配包含特定字符串的字段值,__year和其他时间相关的过滤器可以用于匹配日期和时间。除此之外,还有许多其他过滤器和选项可供选择,如__lt、__gt、__lte以及__gte等等。 总之,使用Django filter多条件过滤功能可以高效、简洁地完成数据筛选任务,而__符号的灵活运用也是Django过滤器的一个重要特征。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值