国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Django對接elasticsearch實現全文檢索的示例代碼

瀏覽:3日期:2024-09-03 13:32:54
目錄前言第一步:首先安裝相關的依賴包第二步:在django項目配置文件settings.py中注冊應用第三步:在django項目配置文件settings.py中指定搜索的后端第四步:創建索引類第五步:在templates目錄中創建text字段使用的模板文件第六步:手動更新索引第七步:創建haystack序列化器第八步:創建視圖類第九步:添加路由第十步:結果前言

說到搜索,第一時間想到的是mysql數據庫的like語句

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

Elasticsearch!

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

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

第一步:首先安裝相關的依賴包

pip install drf-haystack pip install elasticsearch pip install djangorestframework第二步:在django項目配置文件settings.py中注冊應用

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運行的服務器ip地址,端口號固定為9200 ’INDEX_NAME’: ’test’, # 指定elasticsearch建立的索引庫的名稱 }, } # 當添加、修改、刪除數據時,自動生成索引 HAYSTACK_SIGNAL_PROCESSOR = ’haystack.signals.RealtimeSignalProcessor’ # 指定搜索結果每頁的條數 # HAYSTACK_SEARCH_RESULTS_PER_PAGE = 1第四步:創建索引類

在此之前要先創建model類,并插入數據

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

在需要進行索引的應用的目錄下創建文件search_indexes.py, 在該文件內創建該索引類我在app應用下創建: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): '''返回要建立索引的數據查詢集''' return self.get_model().objects.all()第五步:在templates目錄中創建text字段使用的模板文件

創建文件templates/search/indexes/app/es_text.txt文件中定義

{{ object.name }} {{ object.desc }}第六步:手動更新索引

python manage.py rebuild_index #數據庫有多少條數據,全部會被同步到es中第七步:創建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 由序列化類進行返回,第一個參數必須是text第八步:創建視圖類

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第十步:結果

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

到此這篇關于Django對接elasticsearch實現全文檢索的示例代碼的文章就介紹到這了,更多相關Django elasticsearch實現全文檢索內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Django
相關文章:
主站蜘蛛池模板: 国产精品亚欧美一区二区三区 | 美美女高清毛片视频免费观看 | 久久91在线 | a毛片视频| 男女男精品视频免费观看 | 日本高清视频www夜色资源 | 鲁丝一区二区三区不属 | 美女131爽爽爽做爰中文视频 | 亚洲国产精久久久久久久 | 天天综合天天看夜夜添狠狠玩 | 精品国产一区二区三区成人 | 97视频在线免费观看 | 成人精品一区二区久久久 | 久草网首页 | 成人1000部免费观看视频 | 人人99 | 国产啪精品视频网免费 | 欧美怡红院免费的视频 | 伊人365影院 | 亚洲www.| 国产免费久久精品99久久 | 亚洲精品一区二区三区 | 欧美另类在线观看 | 久久99久久99精品 | 亚洲一区免费视频 | 91精品国产综合久久香蕉 | 久草视频福利在线 | 天天看片日本 | 久久欧美精品 | 免费视频 久久久 | 久在线视频| 在线毛片网站 | 亚洲综合成人网 | 免费一级毛片女人图片 | 精品一区二区三区在线播放 | 日本男人的天堂 | 久久99毛片免费观看不卡 | 色偷偷亚洲偷自拍 | 日本黄网站高清色大全 | 69视频成人 | 一级毛片成人免费看a |