文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Django对接elasticsearch怎么实现全文检索

2023-06-20 18:42

关注

这篇文章主要讲解了“Django对接elasticsearch怎么实现全文检索”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Django对接elasticsearch怎么实现全文检索”吧!

目录

前言

说到搜索,第一时间想到的是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怎么实现全文检索这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯