理解ElasticSearch中字段text和keyword的测试实例
keyword不会对字段进行分词,查询的时候必须包含完整的数据。
text会进行分词,使用term的时候查不到,使用match可以查到。
一般不创建mapping的时候会两种都有,所以都可以使用。一开始在这陷入了误区,这种情况类型与我这个例子中的c字段的特点。
一般查询的重点:使用wildcard和不分词(.keyword)进行查询,这个特别类似于关系型数据库里面的通配符匹配查询。使用完整的句子或者内容用通配符进行匹配,这样的匹配无论内容多少都可以查的到。
使用上述数据,进行了测试,测试结果图。查出来的结果为true
1: 7月17日
2: 7月17日每日安全热点 - 西班牙安全公司称阿桑奇干预美国大选
创建索引:
PUT t
{
"mappings":{
"t":{
"properties": {
"a":{
"type": "keyword"
},
"b":{
"type": "text"
},
"c":{
"type": "text",
"fields": {
"keyword": {
"type": "keyword",
"ignore_above": 256
}
}
}
}
}
}
}
插入数据:
PUT t/t/1
{
"a":"7月17日每日安全热点 - 西班牙安全公司称阿桑奇干预美国大选",
"b":"7月17日每日安全热点 - 西班牙安全公司称阿桑奇干预美国大选",
"c":"7月17日每日安全热点 - 西班牙安全公司称阿桑奇干预美国大选"
}
PUT t/t/2
{
"a":"7月17日",
"b":"7月17日",
"c":"7月17日"
}