2012-07-24 58 views
1

我想让用户搜索user模型中多列的其他用户。即first_name,last_nameemail字段。我现在正在进行MySQL全文搜索,但我不相信这是我继续进行的正确方法。是否有人知道MySQL全文搜索如何与Solr和其他第三方提供商联系起来?django +在数据库中搜索

我在寻找searchify和websolr作为潜力。但是对于一个表格来进行3列全文搜索,是否值得呢?

回答

3

对数据库本身进行搜索相当慢。推荐的方法是使用搜索引擎,如Solr,Whoosh等来生成索引。 是一个非常有用的django应用程序,让你抽象搜索引擎并在索引时使用模板。

因此,与模板,你可以有一个模板:

{{user.first_name}} 
{{user. last_name}} 
{{user.email}} 

它将生成的搜索结果你要寻找的。

+0

问题虽然...如果我想使用websolr或任何替代品,可以从自动索引表MySQL数据库自动?找不到任何信息... – KVISH 2012-07-24 13:59:05

+0

是的,这是好事。看看Haystack文档。基本上你会创建一个像我发布的模板,然后运行索引命令;之后,你准备好了。 – leonsas 2012-07-24 15:00:47

+0

此外,为了开发目的,我会推荐使用Python完全编写的Whoosh搜索引擎,并且我觉得使用它进行设置和“播放”要容易得多。 – leonsas 2012-07-24 15:08:32

2

这是我要做的事

#search.py 
import re 

from django.db.models import Q 

def normalize_query(query_string, 
        findterms=re.compile(r'"([^"]+)"|(\S+)').findall, 
        normspace=re.compile(r'\s{2,}').sub): 
    return [normspace(' ', (t[0] or t[1]).strip()) for t in findterms(query_string)] 

def get_query(query_string, search_fields): 
    query = None 
    terms = normalize_query(query_string) 
    for term in terms: 
     or_query = None 
     for field_name in search_fields: 
      q = Q(**{"%s__icontains" % field_name: term}) 
      if or_query is None: 
       or_query = q 
      else: 
       or_query = or_query | q 
     if query is None: 
      query = or_query 
     else: 
      query = query & or_query 
    return query 

和视图:

# views.py 
from django.shortcuts import render_to_response 
from django.contrib.auth.models import User 

def search(request): 
    query = request.GET.get('q', '') 
    if query: 
     entry_query = get_query(query, ['first_name', 'last_name', 'email']) 
     users = User.objects.filter(entry_query).order_by('-pub_date') 
    else: 
     entries_list = [] 
    return render_response(request, 'blog/list.html', {'entries': entries_list}) 
+0

这是什么表现? – KVISH 2012-07-24 13:41:05

+0

我没有任何高流量的网站告诉你,但在一个标准的交通网站工作实际上很棒! – nicowernli 2012-07-24 20:53:54