内容简介:针对嵌套结构的基础知识,可以参考文章文章
嵌套结构
针对嵌套结构的基础知识,可以参考文章 嵌套对象 。
文章 Elasticsearch Nested类型深入详解 对其场景有较好描述:
问题
某个elasticsearch的索引有如下mapping:
"Types": { "type": "nested", "properties": { "FirstTypeName": { "type": "text", "fields": { "Raw": { "type": "keyword", "ignore_above": 256 } }, "analyzer": "ik_smart" }, "Tags": { "type": "text", "fields": { "Raw": { "type": "keyword", "ignore_above": 256 } }, "analyzer": "ik_smart" } } }
描述了商品和(一级分类加二级分类)的一对多关系,两点值得说明:
nested Raw
需要精准搜索时
在业务上需要精准匹配一级分类的时候,需要 term
查询并加强 Raw
属性:
{ "query": { "bool": { "must": { "nested": { "path": "Types", "query": { "bool": { "must": { "term": { "Types.FirstTypeName.Raw": "YJT的数码智能" } } } } } } } } }
需要全文搜索时
在用户搜索场景,需要分类提供一定的score时,则只需要 match
查询:
{ "from": 0, "query": { "function_score": { "boost_mode": "multiply", "field_value_factor": { "factor": 2, "field": "RecentOrderCnt", "modifier": "log2p" }, "max_boost": 4, "query": { "bool": { "must": { "match": { "GoodsName": { "operator": "and", "query": "华为" } } }, "should": { "multi_match": { "fields": [ "Types.FirstTypeName^4", "Types.Tags^4", "Brand^30", "Labels^2" ], "query": "华为", "tie_breaker": 0.1, "type": "best_fields" } } } }, "score_mode": "sum" } }, "size": 2, "sort": [ { "_score": { "order": "desc" } } ] }
需要判断非空时
某些场景必须要求 nested
结构非空时,使用 exists
查询:
111
以上所述就是小编给大家介绍的《elasticsearch的嵌套结构》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 树形结构数据存储方案(五):区间嵌套
- elasticsearch的嵌套结构的两种DSL
- Vardump 更新,支持打印各种 Java 数据结构,支持嵌套
- Vardump 更新,支持打印各种 Java 数据结构,支持嵌套
- MixGo XFMT 解决 Golang 结构体嵌套格式化打印指针地址
- Python 循环嵌套
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
我看电商2(双色)
黄若 / 电子工业出版社 / 2016-6 / 39.00元
《我看电商2》是行业畅销书《我看电商》的续集。 《我看电商》自出版以来,连续印刷14 次,受到业界人士和广大读者的高度好评。《我看电商2》承续作者一贯的风格,以行业观察、经验分享为出发点,重点分析了过去一年中国电商界的最新动态与趋势,包括双11点评、京东关闭拍拍、上市公司私有化等。 电子商务是我国近年来发展最快的新兴行业之一,作者作为这个行业的长老级领军人物,善于思考,长于实操。《我看......一起来看看 《我看电商2(双色)》 这本书的介绍吧!