我希望用户能够在user
模型中的多个列中搜索其他用户。即first_name
,last_name
和email
字段。我现在正在进行MySQL全文搜索,但我不相信这是我继续进行的正确方式。有没有人知道MySQL全文搜索如何与Solr和其他第三方提供商进行叠加?
我正在将searchify和websolr视为潜力。但是对于1个表来对3列进行全文搜索,是否值得呢?
答案 0 :(得分:3)
搜索数据库本身相当慢。推荐的方法是使用搜索引擎,如Solr,Whoosh等来生成索引。 Haystack是一个非常有用的django应用程序,它允许您抽象搜索引擎并在索引时使用模板。
因此,使用模板,您可以拥有如下模板:
{{user.first_name}}
{{user. last_name}}
{{user.email}}
它会生成您正在寻找的搜索结果。
答案 1 :(得分: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})