当前位置: 首页 > news >正文

从MySQL到Elasticsearch:创建酒店索引案例

在现代的数据管理中,Elasticsearch(简称ES)因其强大的搜索功能和灵活的索引结构而受到广泛欢迎。本篇博客将介绍如何根据MySQL数据库中的酒店表定义,创建一个相应的Elasticsearch索引。

MySQL与Elasticsearch的对比

在开始之前,我们需要了解MySQL和Elasticsearch在数据存储和查询方面的不同:

  • MySQL 是一种关系型数据库管理系统,使用表、行和列来组织数据。
  • Elasticsearch 是一个基于Lucene的搜索引擎,提供全文搜索功能,并且能够快速处理大量数据。

酒店表的定义

首先,我们有一个MySQL表 tb_hotel,其定义如下:

CREATE TABLE `tb_hotel` (`id` bigint(20) NOT NULL COMMENT '酒店id',`name` varchar(255) NOT NULL COMMENT '酒店名称;例:7天酒店',`address` varchar(255) NOT NULL COMMENT '酒店地址;例:航头路',`price` int(10) NOT NULL COMMENT '酒店价格;例:329',`score` int(2) NOT NULL COMMENT '酒店评分;例:45,就是4.5分',`brand` nvarchar(32) NOT NULL COMMENT '酒店品牌;例:如家',`city` varchar(32) NOT NULL COMMENT '所在城市;例:上海',`star_name` varchar(16) DEFAULT NULL COMMENT '酒店星级',`business` varchar(255) DEFAULT NULL COMMENT '商圈;例:虹桥',`latitude` varchar(32) NOT NULL COMMENT '纬度',`longitude` varchar(32) NOT NULL COMMENT '经度',`pic` varchar(255) DEFAULT NULL COMMENT '酒店图片',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

创建Elasticsearch索引

根据MySQL表的定义,我们可以创建一个Elasticsearch索引,名为 hotel。以下是创建索引的JSON配置:

PUT /hotel
{"mappings": {"properties": {"id": {"type": "keyword"},"name": {"type": "text","analyzer": "ik_max_word","copy_to": "all"},"address": {"type": "keyword","index": false},"price": {"type": "integer"},"score": {"type": "integer"},"brand": {"type": "keyword","copy_to": "all"},"city": {"type": "keyword","copy_to": "all"},"starName": {"type": "keyword"},"business": {"type": "keyword"},"location": {"type": "geo_point"},"pic": {"type": "keyword","index": false},"all": {"type": "text","analyzer": "ik_max_word"}}}
}

索引字段说明

  • id:使用 keyword 类型,适合精确匹配。
  • namebrand:使用 text 类型,并指定 ik_max_word 分词器,同时复制到 all 字段以支持全文搜索。
  • addresspic:使用 keyword 类型,但 address 不参与索引,pic 不参与索引。
  • pricescore:使用 integer 类型,适合数值比较。
  • city:使用 keyword 类型,并复制到 all 字段。
  • starNamebusiness:使用 keyword 类型,适合分类和标签。
  • location:使用 geo_point 类型,支持地理位置搜索。

结论

通过以上步骤,我们成功地根据MySQL的酒店表定义创建了一个Elasticsearch索引。这将允许我们利用Elasticsearch的强大搜索能力,快速检索和分析酒店数据。记住,索引的创建和维护是一个持续的过程,需要根据实际业务需求不断调整和优化。

http://www.lryc.cn/news/421154.html

相关文章:

  • Webkit与Web Push API:提升用户体验的推送技术
  • Java线程池的拒绝策略
  • 【C++进阶】继承
  • 立体相机镜面重建(一)镜面标定
  • 【如何有效解决前端Vue中的常见难题】
  • CLAMP-1靶机渗透测试
  • JavaScript中的Truthy Falsy值以及等号判断
  • uniapp——展开和收起
  • WebGL2学习(2): GLSL ES 3.0
  • [大模型实战] DAMODEL云算力平台部署LLama3.1大语言模型
  • 驱动开发系列09 - Linux设备模型之设备,驱动和总线
  • HTML实现弹出层
  • Android控件详解
  • 记忆化搜索专题篇
  • 入网测评检查项大全(安全资料)
  • uni-app 开发App时调用uni-push 实现在线系统消息推送通知 保姆教程
  • 13.StringRedisTemplete使用
  • [工具]-gitee+pycharm-配置
  • 中间件是一种在客户端和服务器之间进行通信和处理的软件组件或服务
  • RCE-eval长度限制突破技巧
  • 【黑马】MyBatis
  • oracle创建dblink使得数据库A能够访问数据库B表LMEAS_MFG_FM的数据
  • git config 如何配置用户账户
  • SpringBoot基础(二):配置文件详解
  • Web安全(一)-靶场搭建过程-基于docker
  • 【JavaEE】单例模式和阻塞队列
  • RCE绕过技巧
  • Spring源码解析(31)之事务配置文件解析以及核心对象创建过程
  • win11安装docker报错记录
  • 【vulnhub】CLAMP 1.0.1靶机