内容简介:针对嵌套结构的基础知识,可以参考文章文章
嵌套结构
针对嵌套结构的基础知识,可以参考文章 嵌套对象 。
文章 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 循环嵌套
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据库系统概念
(美)Abraham Silberschatz、(美)Henry F.Korth、(美)S.Sudarshan / 杨冬青、李红燕、唐世渭 / 机械工业出版社 / 2012-3 / 99.00元
【编辑推荐】 数据库领域的殿堂级作品 夯实数据库理论基础,增强数据库技术内功的必备之选 对深入理解数据库,深入研究数据库,深入操作数据库都具有极强的指导作用! 【内容简介】 本书是数据库系统方面的经典教材之一,其内容由浅入深,既包含数据库系统基本概念,又反映数据库技术新进展。它被国际上许多著名大学所采用,包括斯坦福大学、耶鲁大学、得克萨斯大学、康奈尔大学、伊利诺伊大学......一起来看看 《数据库系统概念》 这本书的介绍吧!
JSON 在线解析
在线 JSON 格式化工具
html转js在线工具
html转js在线工具