前言:
在es 2.*版本里面是没有这两个字段,只有string字段。
5.*之后,把string字段设置为了过时字段,引入text,keyword字段
那么今天我们来看一下,es在5.*之后,字符串类型的mapping应该怎么设置
实践:
准备工作:
es在5.*之后,string类型常用三种,
1.默认的,就是我们不设置mapping直接往里面插入数据
2.我们设置mapping为text
3.我们设置mapping为keyword,将2里面的text改为keyword
4.我们分别往里面添加一个字段 name:张三李四,然后分别查找张三
添加: 查找:
结论一:我们发现类型为keyword的无法查找,可以得出keyword不支持分词查询 ,但另外两个支持
5.我们继续三个索引里面继续添加姓名(添加几个一样的),此时我们要统计姓名相同的人的人数,那么我们必须用到聚合查询
查询text索引时,直接说不行
查询xuzhan索引时,要在聚合字段加一个keyword就行
查询key时,可以
结论二:text类型无法聚合查询
那么至此我们可以总结出这三个在查询上的优缺点了
总结
分词 聚合
keyword 不支持 支持
text 支持 不支持
默认 支持 支持
此时的你是不是在想那以后就直接用默认类型就行了,万能的,但是,但是,但是
经过上面的测试,可以发现text类型在存储数据的时候会默认进行分词,并生成索引。而keyword存储数据的时候,不会分词建立索引,显然,这样划分数据更加节省内存。为了性能考虑,我们应该仔细斟酌一下 text or keyword ?
本着资源共享的原则,欢迎各位朋友在此基础上完善,并进一步分享,让我们的实现更加优雅。如果有任何疑问和需要进一步交流可以留言沟通
Testner创始人(testner.club) Sea