标签:index string keyword 字段 ElasticSearch type 分词 store productID
先说结论:字段类型更改为 'keyword'
elasticSearch官方文档中创建index代码如下
PUT /my_store { "mappings" : { "products" : { "properties" : { "productID" : { "type" : "string", "index" : "not_analyzed" } } } } }
由于es官方文档版本基于2.x编写,而本人安装版本为6.6 在执行如上代码过程中出现如下错误
No handler for type [string] declared on field [productID]
这里报错是因为ElasticSearch5.x以上版本没有string类型了,换成了text和keyword作为字符串类型。
字符串 - text:用于全文索引,该类型的字段将通过分词器进行分词,最终用于构建索引
字符串 - keyword:不分词,只能搜索该字段的完整的值,只用于 filtering
此时我们将文档中代码更改为如下
PUT /my_store { "mappings" : { "products" : { "properties" : { "productID" : { "type" : "keyword", "index": true } } } } }
创建成功,此时我们进行查询试试看
GET /my_store/products/_search { "query" : { "constant_score" : { "filter" : { "term" : { "productID" : "XHDK-A-1293-#fJ3" } } } } }
标签:index,string,keyword,字段,ElasticSearch,type,分词,store,productID 来源: https://www.cnblogs.com/cfas/p/16142883.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。