Question

Je le modèle suivant

class Command(models.Model):
    server = models.ForeignKey(Server)
    user_login = models.CharField(max_length=100)
    user_run = models.CharField(max_length=100)
    host = models.CharField(max_length=100)
    ip = models.CharField(max_length=100)
    session = models.CharField(max_length=100)
    command = models.TextField()
    ts = models.DateTimeField(auto_now_add=True)
    version = models.CharField(max_length=100)
    type = models.CharField(max_length=100)

J'ai la requête de recherche suivante

cmds = Command.objects.filter(Q(user_login__contains=form.cleaned_data['loguser']),
                              Q(user_run__contains=form.cleaned_data['runuser']),
                              Q(host__contains=form.cleaned_data['loghost']),
                              Q(command__contains=form.cleaned_data['command']),
                              Q(server__contains=form.cleaned_data['host']),
                              Q(session__contains=form.cleaned_data['session'])) \
                      .order_by('-id')[:100]

Je dois effectuer une recherche par la chaîne suivante pour server.host

Si j'essaie d'ajouter ce qui suit, je reçois une erreur

Q(server__contains=form.cleaned_data['host']),

Exception Type:     TypeError
Exception Value:    

Related Field has invalid lookup: contains

Exception Location:     /usr/lib/python2.5/site-packages/django/db/models/fields/related.py in get_db_prep_lookup, line 156

form.cleaned_data [ 'host'] contiendra une chaîne de texte pour un nom d'hôte.

Était-ce utile?

La solution

server__searchfieldname__contains

vous ne spécifiez pas ce champ dans le tableau de serveur doit rechercher.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top