2016-04-15 10 views
0

Ich habe ein Modell wie folgt aus:django mehrere Abfragefilter - Spiel 1 oder 2 Felder

class Result(models.Model): 
    title = models.CharField(max_length=300) 
    desc = models.TextField(max_length=800) 
    url = models.CharField(max_length=200) 
    rank = models.BigIntegerField() 
    category = models.ForeignKey('Category') 
    tags = TaggableManager() 
    def __str__(self): 
     return self.title 
    class Meta: 
     verbose_name_plural = "Risultati" 

class Category(models.Model): 
    title = models.CharField(max_length=300) 
    slug = models.SlugField(null=True) 
    def __str__(self): 
     return self.title 
    class Meta: 
     verbose_name_plural = "Categorie" 

und Ansichten:

def search_form(request): 
    return render(request, 'search.html') 

def result(request): 
    if 'q' in request.GET and request.GET['q']: 
     q = request.GET['q'] 
     results = Result.objects.filter(tags__name__in=[q], desc__icontains=q).order_by('-rank') 
     return render(request, 'results.html', {'results': results, 'query': q}) 
    else: 
     return render(request, 'search.html', {'error': True}) 

def detail(request, result_id): 
    try: 
     result = Result.objects.get(pk=result_id) 
    except Result.DoesNotExist: 
     raise Http404("Nessun risultato :(") 
    return render(request, 'detail.html', {'result': result}) 

i durch Filter, Tags oder DESC suchen müssen, ich versuche, den filter() zu verketten filter() aber nichts passiert, wo ist der fehler?

Antwort

0

Verkettungsausdrücke entweder in demselben filter() oder in separaten führt eine implizite AND. Wenn Sie einen OR oder einen expliziten AND ausführen möchten, müssen Sie stattdessen Q objects verwenden.

....filter(Q(tags__name__in=[q]) | Q(desc__icontains=q)).... 
+0

danke, perfekt! – user0111001101