keyword:存储数据时候,该类型的字段不会分词建立索引
text:存储数据时候,会自动分词,并生成索引
数据准备
PUT /test
{
"mappings": {
"properties": {
"name":{
"type": "keyword"
},
"desc":{
"type": "text"
}
}
}
}
POST /test/_doc
{
"name":"梦露",
"desc":"性感魅力"
}
POST /test/_doc
{
"name":"奥黛丽·赫本",
"desc":"光芒四射"
}
模糊查询keyword类型字段
GET /test/_search
{
"query": {
"match": {
"name": "梦"
}
}
}
运行结果:
{
"took" : 0,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 0,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
}
}
模糊查询text类型字段
POST /test/_search
{
"query": {
"match": {
"desc": "芒"
}
}
}
运行结果
{
"took" : 0,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.6931471,
"hits" : [
{
"_index" : "test",
"_type" : "_doc",
"_id" : "JASwgHQByM5jgHs7lImo",
"_score" : 0.6931471,
"_source" : {
"name" : "奥黛丽·赫本",
"desc" : "光芒四射"
}
}
]
}
}
精确查询keyword类型字段
POST /test/_search
{
"query": {
"term": {
"name": "梦露"
}
}
}
运行结果:
{
"took" : 0,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 1,
"relation" : "eq"
},
"max_score" : 0.6931471,
"hits" : [
{
"_index" : "test",
"_type" : "_doc",
"_id" : "HgSwgHQByM5jgHs7XYkt",
"_score" : 0.6931471,
"_source" : {
"name" : "梦露",
"desc" : "性感魅力"
}
}
]
}
}
精确查询text类型字段
POST /test/_search
{
"query": {
"term": {
"desc": "光芒四射"
}
}
}
查询结果:
{
"took" : 0,
"timed_out" : false,
"_shards" : {
"total" : 1,
"successful" : 1,
"skipped" : 0,
"failed" : 0
},
"hits" : {
"total" : {
"value" : 0,
"relation" : "eq"
},
"max_score" : null,
"hits" : [ ]
}
}