首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用SearchQuerySet过滤海量结果

使用SearchQuerySet过滤海量结果
EN

Stack Overflow用户
提问于 2011-09-08 23:58:41
回答 1查看 2.1K关注 0票数 1

我正在使用haystack和whoosh,试图将搜索结果限制为仅由当前登录的用户创建的条目。我为其创建了索引的类别模型有一个外键:

代码语言:javascript
复制
user = models.ForeignKey(User, editable=False)

在我的自定义搜索视图中,我想像这样过滤:

代码语言:javascript
复制
searchqueryset = SearchQuerySet().filter(user=request.user.id)

form = SearchForm(request.GET, searchqueryset=searchqueryset, load_all=True)

    if form.is_valid():
        query = form.cleaned_data['q']
        results = form.search()

在数据库中,表category有一个条目:

代码语言:javascript
复制
id  name    user_id 
1   test10  1   

并且当前的用户id确实是1。但是我没有得到任何结果。

当我这样做的时候:

代码语言:javascript
复制
searchqueryset = None

我得到了"test10“类别条目。那么,有人知道为什么用户id过滤器不能像预期的那样工作吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-09-09 01:13:45

你确定你的Haystack索引中的" user“包含了用户id的整数值吗?也许它有一些其他的用户数据(如用户名),所以比较根本不起作用?

默认情况下,Django user对象返回用户名,而不是用户id。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7351038

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档