读《深入理解Elasticsearch》点滴-对象类型、嵌套文档、父子关系
2024-09-01 11:34:41
一、对象类型
1、mapping定义文件
"title":{
"type":"text"
},
"edition":{
"type":"object",
"properties":{
"isbn":{
"type":"text"
}
}
}
2、索引数据
"title":"title_1",
"edition":[
{
"isbn":"",
"circulation":50000
},
{
"isbn":"",
"circulation":2000
}
]
3、等效于
"title":"title_1",
"edition"
{
"isbn":["",""],
"circulation":[,]
}
4、总结一下:
object类型只有在很简单的情景中好用,如“一对一“的父子环境当中;或者不存在跨字段找找等情况是,仅需要在单个字段中搜索而不需要关联多个字段时,或者不需要在对象中搜索。
二、嵌套文档
1、mapping定义
"title":{
"type":"text"
},
"edition":{
"type":"nested",
"properties":{
"isbn":{
"type":"text"
} }
}
2、总结
- 普通查询,嵌套文档被自动过滤掉,不会被搜索到或展示出来。这在Lucene中被称为块链接(block join)。出于性能方面的考虑,嵌套文档与主文档保存在一个索引块中
- 主文档与嵌套文档在索引期间同时存储的,又称为“索引期连接(index-time join)。
- 当主文档和嵌套文档都很小,且主文档易于获取时,这种强关联关系并不会造成什么问题。如果这些文档很大,关联双方之一变化频繁,那么重建另外一部分文档变得不太现实里。
- 另外就是如果一个嵌套文档属于多个主文档时,问题会变得非常棘手。
三、parent-child 关系
1、最大的优势,父子关系双方的文档是相互独立的,又称为”查询期连接(query-time join)。
2、代价就是更复杂的查询及更慢的查询性能
3、第二个优势:父子关系适用于大型应用及多节点场景
4、子文档检索并不强制在父文档上下文中进行
5、一个异常的例子:
父数据有1000条,通过hash存储到不同的分片上;
子数据有1000条,所有子数据的对应同一条父数据;
1000条子数据都将存储到同一个分片上。
6、如果某些分文档有多个子文档,会导致文档在分片之间的不均匀分布
最新文章
- Java基础-输入输出-3.编写BinIoDemo.java的Java应用程序,程序完成的功能是:完成1.doc文件的复制,复制以后的文件的名称为自己的学号姓名.doc。
- 这个jQuery导航菜单怎么样
- mount -t nfs 的使用
- SpringMVC Controller介绍
- Java并发编程:并发容器之ConcurrentHashMap
- 配置HylaFAX传真服务器
- MySQL(26):事务的隔离级别出现问题之 幻读
- C#_wpf_userinput_数据绑定_后台对象改变,界面数据也变化
- Interfaces
- Matlab实现Hough变换检測图像中的直线
- java Double保留小数点位数
- stl_container容器和std_algorithm算法相同的函数
- sharepoint 2013 使用SharePoint powershell 2013更改搜索server方法
- vue-cli: render:h =>; h(App)是什么意思
- limits.conf文件工作原理
- docker下搭建zipkin for mysql
- 程序员的快速开发框架:Github上 10 大优秀的开源后台控制面板
- android sdk 编译--如何将源代码加入android.jar,以及make原理
- Gitlab CI-2.CI流程
- 关于 C# HttpClient的 请求