1

userユーザーがモデルの複数の列で他のユーザーを検索できるようにしたい。つまり、、、first_nameおよびlast_nameフィールドemail。私は今のところMySQL全文検索を行っていますが、それが私にとって正しい方法であるとは確信していません。MySQLの全文検索がSolrや他のサードパーティプロバイダーとどのように重なるか知っている人はいますか?

私は、searchifyとwebsolrを可能性として見ています。しかし、1つのテーブルで3つの列にわたって全文検索を行うには、それだけの価値がありますか?

4

2 に答える 2

3

データベース自体に対する検索はかなり遅いです。推奨されるアプローチは、Solr、Whooshなどの検索エンジンを使用してインデックスを生成することです。Haystackは非常に便利なdjangoアプリで、検索エンジンを抽象化し、インデックス作成時に使用するテンプレートを用意できます。

したがって、テンプレートを使用すると、次のようなテンプレートを作成できます。

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

そしてそれはあなたが探している検索結果を生成します。

于 2012-07-24T04:08:30.007 に答える
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})
于 2012-07-24T04:42:01.860 に答える