濮阳杆衣贸易有限公司

主頁 > 知識庫 > Django對接elasticsearch實現(xiàn)全文檢索的示例代碼

Django對接elasticsearch實現(xiàn)全文檢索的示例代碼

熱門標簽:宿州電話機器人哪家好 旅游廁所地圖標注怎么弄 西青語音電銷機器人哪家好 電梯新時達系統(tǒng)外呼顯示e 地圖標注與注銷 百應(yīng)電話機器人總部 成都呼叫中心外呼系統(tǒng)哪家強 無錫智能外呼系統(tǒng)好用嗎 南昌地圖標注

前言

說到搜索,第一時間想到的是mysql數(shù)據(jù)庫的like語句

但是,假如你的數(shù)據(jù)庫有幾千萬條數(shù)據(jù),name字段沒有索引,可能查詢需要十幾分鐘,用戶可能會等你?那為什么不給name字段增加索引?數(shù)據(jù)表不僅僅是用來查詢,也會經(jīng)常修改數(shù)據(jù),新增刪除數(shù)據(jù)等。建立索引后,做增刪改操作時也會大大占用數(shù)據(jù)庫資源。所以應(yīng)該怎么解決呢?

Elasticsearch!

一個強大的基于Lucene的全文搜索服務(wù)器!維基百科、Stack Overflow、Github都在用。

如果想詳細了解其原理的話,可以參考:https://www.elastic.co/guide/index.html

第一步:首先安裝相關(guān)的依賴包

pip install drf-haystack 
pip install elasticsearch 
pip install djangorestframework

第二步:在django項目配置文件settings.py中注冊應(yīng)用

INSTALLED_APPS = 
[
'app.apps.AppConfig', 
'haystack', 
'rest_framework'
]

第三步:在django項目配置文件settings.py中指定搜索的后端

HAYSTACK_CONNECTIONS = { 
'default':    {
            'ENGINE':'haystack.backends.elasticsearch_backend.ElasticsearchSearchEngine', 
            'URL': 'http://127.0.0.1:9200/', # 此處為elasticsearch運行的服務(wù)器ip地址,端口號固定為9200 
            'INDEX_NAME': 'test', # 指定elasticsearch建立的索引庫的名稱 
            }, 
            } 
# 當添加、修改、刪除數(shù)據(jù)時,自動生成索引 
HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor' 
# 指定搜索結(jié)果每頁的條數(shù) 
# HAYSTACK_SEARCH_RESULTS_PER_PAGE = 1

第四步:創(chuàng)建索引類

在此之前要先創(chuàng)建model類,并插入數(shù)據(jù)

from django.db import models 
class Es(models.Model): 
    name=models.CharField(max_length=32)
    desc=models.CharField(max_length=32)

在需要進行索引的應(yīng)用的目錄下創(chuàng)建文件search_indexes.py, 在該文件內(nèi)創(chuàng)建該索引類
我在app應(yīng)用下創(chuàng)建:search_indexes.py

# 索引模型類的名稱必須是 模型類名稱 + Index 
from haystack import indexes 
from .models import Es 
class EsIndex(indexes.SearchIndex, indexes.Indexable): 
    text = indexes.CharField(document=True, use_template=True) 
    def get_model(self): 
    """返回建立索引的模型類""" 
        return Es 
    def index_queryset(self, using=None): 
    """返回要建立索引的數(shù)據(jù)查詢集""" 
        return self.get_model().objects.all()

第五步:在templates目錄中創(chuàng)建text字段使用的模板文件

創(chuàng)建文件templates/search/indexes/app/es_text.txt文件中定義

{{ object.name }} 
{{ object.desc }}

第六步:手動更新索引

python manage.py rebuild_index   #數(shù)據(jù)庫有多少條數(shù)據(jù),全部會被同步到es中

第七步:創(chuàng)建haystack序列化器

from drf_haystack.serializers 
import HaystackSerializer 
from rest_framework.serializers 
import ModelSerializer from app 
import models 
from app.search_indexes import EsIndex 
class EsSerializer(ModelSerializer): 
    class Meta: 
        model=models.Es 
        fields='__all__' 
class EsIndexSerializer(HaystackSerializer): 
     object = EsSerializer(read_only=True) # 只讀,不可以進行反序列化 
     class Meta: 
        index_classes = [EsIndex]# 索引類的名稱 
        fields = ('text', 'object')# text 由索引類進行返回, object 由序列化類進行返回,第一個參數(shù)必須是text

第八步:創(chuàng)建視圖類

from drf_haystack.viewsets 
import HaystackViewSet 
from app.models import Book 
from app.serializers import EsIndexSerializer 
class EsSearchView(HaystackViewSet): 
    index_models = [Es] 
    serializer_class = EsIndexSerializer

第九步:添加路由

from django.conf.urls 
import url from django.contrib 
import admin 
from rest_framework import routers 
from app.views import EsSearchView 
    router = routers.DefaultRouter() 
    router.register("book/search", EsSearchView, base_name="book-search") 
    urlpatterns = [ url(r'^admin/', admin.site.urls), ] 
    urlpatterns += router.urls

第十步:結(jié)果

http://127.0.0.1:8000/?text=測試

到此這篇關(guān)于Django對接elasticsearch實現(xiàn)全文檢索的示例代碼的文章就介紹到這了,更多相關(guān)Django elasticsearch實現(xiàn)全文檢索內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang elasticsearch Client的使用詳解
  • Django利用elasticsearch(搜索引擎)實現(xiàn)搜索功能
  • golang操作elasticsearch的實現(xiàn)
  • Django項目之Elasticsearch搜索引擎的實例
  • django使用haystack調(diào)用Elasticsearch實現(xiàn)索引搜索
  • Go語言Elasticsearch數(shù)據(jù)清理工具思路詳解

標簽:贛州 辛集 西安 雅安 濰坊 許昌 七臺河 渭南

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Django對接elasticsearch實現(xiàn)全文檢索的示例代碼》,本文關(guān)鍵詞  Django,對接,elasticsearch,實現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django對接elasticsearch實現(xiàn)全文檢索的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Django對接elasticsearch實現(xiàn)全文檢索的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    温州市| 南开区| 永康市| 夏河县| 瓦房店市| 内乡县| 桐梓县| 梅河口市| 凌源市| 新巴尔虎左旗| 图木舒克市| 忻州市| 武山县| 曲水县| 通州区| 平塘县| 当涂县| 延川县| 金乡县| 吉林省| 南岸区| 汤阴县| 策勒县| 蒙城县| 海口市| 博客| 青田县| 丽江市| 浑源县| 唐海县| 肇源县| 林西县| 黔西| 渝中区| 新野县| 淄博市| 玉环县| 长白| 鹤岗市| 封开县| 平罗县|