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

Elasticsearch 创建索引 Mapping映射属性 索引库操作 增删改查

Mapping Type映射属性

mapping是对索引库中文档的约束,有以下类型。

  • text:用于分析和全文搜索,通常适用于长文本字段。
  • keyword:用于精确匹配,不会进行分析,适用于标签、ID 等精确匹配场景。
  • integer、long、float、double:用于存储数字数据。
  • date:用于存储日期数据。
  • boolean:用于存储布尔值(true/false)。
  • object:用于嵌套对象,通常用于存储结构化的数据。
  • nested:与 object 类似,但允许嵌套查询。

Index属性
index 属性用于字段映射(mapping)中,来指示该字段是否被索引、是否可搜索,或者是否需要其他特殊的处理。该属性的设置直接影响字段的存储方式和搜索效率。在实际开发中,会有一些附带的值这些值并不需要搜索,如:备注,商品的封面URL等他默认是Index:true,需给这些字段设置成false。

analyzer 分词器
指定使用哪个分词器。

properties字段
用来表示字段。


索引库操作

Elasticsearch提供的所有API都是Restful的接口,遵循Restful的基本规范。
在这里插入图片描述

创建索引库

商品表字段
在这里插入图片描述
抽出搜索商品的字段
抽出搜索商品的字段在es创建索引。

  • 商品名称:参与搜索
  • 商品价格:参与搜索,按价格区间搜索
  • 商品封面:不参与搜索,搜索时需要一起返回
  • 限购次数:不参与搜索,搜索时需要一起返回

请求方式:PUT http://172.23.4.130:9200/goods

  • goods 库名
  • PUT Restful 风格
{
    "mappings": {
        "properties": {
            "title": {
                "type": "text",
                "analyzer": "ik_smart"
            },
            "pie": {
                "type": "long"
            },
            "cover":
            {
                "type": "keyword",
                "index": false
            },
            "quota":{
                "type": "keyword",
                "index": false
            }
        }
        }
}

创建成功

{
    "acknowledged": true,
    "shards_acknowledged": true,
    "index": "goods"
}

查询所有

请求方式:GET http://172.23.4.130:9200/goods

查询成功

{
    "goods": {
        "aliases": {},
        "mappings": {
            "properties": {
                "cover": {
                    "type": "keyword",
                    "index": false
                },
                "pie": {
                    "type": "long"
                },
                "quota": {
                    "type": "keyword",
                    "index": false
                },
                "title": {
                    "type": "text",
                    "analyzer": "ik_smart"
                }
            }
        },
        "settings": {
            "index": {
                "routing": {
                    "allocation": {
                        "include": {
                            "_tier_preference": "data_content"
                        }
                    }
                },
                "number_of_shards": "1",
                "provided_name": "goods",
                "creation_date": "1735986796036",
                "number_of_replicas": "1",
                "uuid": "jCkFMX3qSzimtWEmWHvpwQ",
                "version": {
                    "created": "7120199"
                }
            }
        }
    }
}

删除索引库

请求方式:DELETE http://172.23.4.130:9200/goods


修改索引库

在Elasticsearch不可以对已有的索引进行修改,但是可以添加新的索引。

请求方式:PUT http://172.23.4.130:9200/goods/_mapping

{

    "properties": {
      "id": {
        "type": "keyword",
        "index": false
      }
    } 
}

http://www.kler.cn/a/470857.html

相关文章:

  • ECharts系列:echart中折线图折线设置不平滑显示
  • 基于SMT32U575RIT单片机-中断练习
  • ffmpeg7.0 合并2个 aac 文件
  • iOS - 自定义引用计数(MRC)
  • ComfyUI节点安装笔记
  • nodeJS下npm和yarn的关系和区别详解
  • C++:const和constexpr两个关键字
  • 【C++数据结构——线性表】顺序表的基本运算(头歌实践教学平台习题)【合集】
  • springboot+vue实现SSE服务器发送事件
  • 【OceanBase】利用 OceanBase 向量检索能力构建文档智能问答小助手
  • 6 网络编程
  • 小程序组件 —— 26 组件案例 - 跳转到商品列表
  • Unity-Mirror网络框架-从入门到精通 总目录
  • C# delegate 委托使用教程
  • 【Linux】sed编辑器
  • 周记-Repeater中的children和item区别
  • Go语言的 的抽象类(Abstract Classes)核心知识
  • 图数据库 | 17、高可用分布式设计(上)
  • Elixir语言的学习路线
  • 像素越多越好?像元的面积越小越好?
  • QT ---------------数据库编程概要
  • 自组织映射 (Self-Organizing Map, SOM) 算法详解与PyTorch实现
  • XXL-RPC v1.8.1 | RPC服务框架
  • 去耦电容理解:“耦”了什么?非要“去”了?
  • Bash语言的软件工程
  • 模电面试——设计题及综合分析题0x03(含答案)