6

我已经MultivaluedField在我的索引(干草堆)中添加了一个,我需要搜索一个 ManyToMany 相关字段,但它不起作用。

引擎是嗖嗖的。

这是我的索引的样子:

 class PostIndex(SearchIndex):
     text = CharField(document=True, use_template=True)
     author = CharField(model_attr='author') 
     body = CharField(model_attr='body') 
     pub_date = DateTimeField(model_attr='publish') 
     regions = MultiValueField() 
 
 def prepare_regions(self, obj):
     return [region.name for region in obj.regions.all()]

这就是我的模型的样子:

 class Post(models.Model):

     title           = models.CharField(_('title'), max_length=200)
     author          = models.ForeignKey(User, blank=True, null=True)
     body            = models.TextField(_('body'), )
     allow_comments  = models.BooleanField(_('allow comments'), default=True)
     publish         = models.DateTimeField(_('publish'), default=datetime.datetime.now)
     categories      = models.ManyToManyField(Category, blank=True)
     tags            = TagField()
     objects         = PublicManager()

     regions         = models.ManyToManyField(Region, blank=True)

如果我使用SearchQuerySet().filter(region__in=words_list)它就可以了。问题是我不知道用户何时搜索区域或另一个字段,所以我必须使用SearchQuerySet().filter(content__icontains=words_list). 这样一来,什么也找不到。

谢谢

谢谢!!

4

2 回答 2

0

尝试 :

class PostIndex(SearchIndex):
 text = CharField(document=True, use_template=True)
 author = CharField(model_attr='author') 
 body = CharField(model_attr='body') 
 pub_date = DateTimeField(model_attr='publish') 

 regions = CharField(model_attr='regions')
于 2011-08-13T00:00:36.900 回答
0

您只需将区域 id 添加到区域的索引中。

尝试

    def prepare_regions(self, obj):
        return [region.pk for region in obj.regions.all()]
于 2015-07-21T16:48:32.663 回答