我想讓用戶搜索user
模型中多列的其他用戶。即first_name
,last_name
和email
字段。我現在正在進行MySQL全文搜索,但我不相信這是我繼續進行的正確方法。是否有人知道MySQL全文搜索如何與Solr和其他第三方提供商聯繫起來?django +在數據庫中搜索
我在尋找searchify和websolr作爲潛力。但是對於一個表格來進行3列全文搜索,是否值得呢?
我想讓用戶搜索user
模型中多列的其他用戶。即first_name
,last_name
和email
字段。我現在正在進行MySQL全文搜索,但我不相信這是我繼續進行的正確方法。是否有人知道MySQL全文搜索如何與Solr和其他第三方提供商聯繫起來?django +在數據庫中搜索
我在尋找searchify和websolr作爲潛力。但是對於一個表格來進行3列全文搜索,是否值得呢?
對數據庫本身進行搜索相當慢。推薦的方法是使用搜索引擎,如Solr,Whoosh等來生成索引。 是一個非常有用的django應用程序,讓你抽象搜索引擎並在索引時使用模板。
因此,與模板,你可以有一個模板:
{{user.first_name}}
{{user. last_name}}
{{user.email}}
它將生成的搜索結果你要尋找的。
這是我要做的事
#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})
這是什麼表現? – KVISH 2012-07-24 13:41:05
我沒有任何高流量的網站告訴你,但在一個標準的交通網站工作實際上很棒! – nicowernli 2012-07-24 20:53:54
問題雖然...如果我想使用websolr或任何替代品,可以從自動索引表MySQL數據庫自動?找不到任何信息... – KVISH 2012-07-24 13:59:05
是的,這是好事。看看Haystack文檔。基本上你會創建一個像我發佈的模板,然後運行索引命令;之後,你準備好了。 – leonsas 2012-07-24 15:00:47
此外,爲了開發目的,我會推薦使用Python完全編寫的Whoosh搜索引擎,並且我覺得使用它進行設置和「播放」要容易得多。 – leonsas 2012-07-24 15:08:32