我正在try 根据用户输入标签查询数据库.标记的数量可以从0到5,所以我需要动态创建查询.
因此,我有一个标记列表TAG_LIST,并且我想查询数据库:
design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )
如何创建此功能?
我正在try 根据用户输入标签查询数据库.标记的数量可以从0到5,所以我需要动态创建查询.
因此,我有一个标记列表TAG_LIST,并且我想查询数据库:
design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )
如何创建此功能?
你需要在标签列表中循环,并 for each 标签应用一个过滤器.
tag_list = ['tag1', 'tag2', 'tag3']
base_qs = Design.objects.all()
for t in tag_list:
base_qs = base_qs.filter(tags__tag__contains=t)
这将为您提供与all个标签匹配的结果,如您的示例中的and
个标签所示.如果您实际上需要or
,那么您可能需要Q对象.
我想我有你现在要找的东西.
tags = ['tag1', 'tag2', 'tag3']
q_objects = Q() # Create an empty Q object to start with
for t in tags:
q_objects |= Q(tags__tag__contains=t) # 'or' the Q objects together
designs = Design.objects.filter(q_objects)
我测试了一下,它似乎工作得很好.
Edit 2:把最初的 idea 归功于#Django on Freenode中的kezabelle.