ElasticSearch 5.0以后,移除了string类型,string字段被拆分成两种新的数据类型:
text用于全文搜索的, 而keyword用于关键词搜索。
ElasticSearch字符串将默认被同时映射成text和keyword类型,将会自动创建下面的动态映射(dynamic mappings):
“code”: {
“type”: “text”,
“fields”: {
“keyword”: {
“ignore_above”: 256,
“type”: “keyword”
}
}
},
这就是造成部分字段还会自动生成一个与之对应的“.keyword”字段的原因
Text keyword
Text:会分词,然后进行索引
支持模糊、精确查询
不支持聚合
keyword:不进行分词,直接索引
支持模糊、精确查询
支持聚合
es嵌套查询
192.168.2.6 192168.2.7
.2.6 查询因为默认将字符串被同时映射成text和keyword类型
2.6 查询因为将字符串指定keyword类型
导致同样的语句一个有数据、一个为空,
列:2.6
{
“query”: {
“bool”: {
“should”: [
{
“nested”: {
“query”: {
“bool”: {
“must”: [
{
“term”: {
“listWyj.