一.查询方式
大部分情况下,使用es进行查询,只需要使用它的叶子查询,有以下查询方式:
模糊匹配 | 精准匹配 |
---|---|
match:通过关键词匹配条件内容 | term:单个条件相当 |
prefix:前缀匹配 | terms:单个字段属于某个值数组内的值 |
regexp:正则表达式匹配 | range:字段属于某个范围 |
exists:某个字段值是否存在 | |
ids:通过id查询 |
模糊匹配
- 一般用于匹配文本类的内容,比如text类型、keyword类型
- 模糊匹配会对搜索条件进行分词,比如,搜索条件为“艾卡西亚暴雨”,可能会被分词为“艾卡西亚暴雨”、“艾卡西亚”、“暴雨”(具体分词粒度是由所设定的分词器决定的),通过倒排索引查询符合这三个分词的数据
精确匹配
- 精确匹配是不会对搜索条件进行分词的,搜索“艾卡西亚暴雨”,那只能查回来符合“艾卡西亚暴雨”的数据
二.映射
首先,映射的含义就是,你存到es里的数据,每一个属性会被定义为一个特定的数据类型,和mysq里定义数据类型是一个意思
但是,es是支持动态映射的,什么叫动态映射呢?意思是即使创建索引的时候没有主动定义映射规则,es也会自动在存储数据的时候根据文档里的字段自动定义好数据类型
它的动态映射规则如下:
当然,es支持静态映射,也就是你可以在建立索引的时候定义好你想定义的字段的数据类型
而常用的字符串类型数据在es里除了可以被定义为text类型外,还可以定义为keyword类型,那这两种类型有什么不同呢
text
- text类型的数据会被分词,转化为词的组合,建立倒排索引
- text类型的数据不能用来排序和聚合
keyword
- keyword类型的数据不会被分词
- keyword类型的数据可以用来检索过滤、排序和聚合