【Elasticsearch】映射:詳解 _source store 字段

映射:詳解 _source & store 字段

  • 1._source 字段
    • 1.1 特點
    • 1.2 示例
  • 2.store 字段
    • 2.1 特點
    • 2.2 示例
  • 3.兩者對比
    • 3.1 使用建議
    • 3.2 實際應用示例

1._source 字段

_source 是 Elasticsearch 中一個特殊的元字段,它存儲了文檔在索引時的原始 JSON 內容。

1.1 特點

  • 默認啟用:所有文檔都會自動存儲原始 JSON 數據在 _source 中。
  • 完整存儲:保存文檔的完整原始結構。
  • 重要用途
    • 返回搜索結果中的原始文檔內容。
    • 支持高亮顯示。
    • 支持重新索引操作。
    • 支持更新文檔(因為需要原始內容)。

1.2 示例

PUT my_index/_doc/1
{"title": "Elasticsearch Guide","author": "John Doe","content": "This is a comprehensive guide..."
}GET my_index/_doc/1

返回結果中會包含完整的 _source 內容。

在這里插入圖片描述

禁用 _source

PUT my_index
{"mappings": {"_source": {"enabled": false}}
}

禁用后無法獲取原始文檔內容,且某些功能將不可用。

在這里插入圖片描述

2.store 字段

store 是字段級別的屬性,決定是否將字段值單獨存儲在 Lucene 中(獨立于 _source)。

2.1 特點

  • 默認關閉:大多數情況下不需要單獨存儲字段。
  • 特定場景使用
    • 當只需要檢索個別字段,而不需要整個 _source 時。
    • _source 被禁用,但仍需要某些字段時。
  • 存儲方式:以列式存儲,單獨存儲。

2.2 示例

PUT my_index
{"mappings": {"properties": {"title": {"type": "text","store": true },"content": {"type": "text"}}}
}

檢索存儲字段。

GET my_index/_search
{"stored_fields": ["title"] 
}

在這里插入圖片描述

3.兩者對比

特性_source 字段store 屬性
存儲級別文檔級(整個原始文檔)字段級(單個字段)
默認值啟用禁用
存儲方式原始 JSON單獨列式存儲
主要用途獲取完整文檔、重新索引、更新等操作高效檢索特定字段
存儲開銷較高(存儲完整文檔)較低(只存儲指定字段)
檢索方式通過 _source 獲取通過 stored_fields 獲取

3.1 使用建議

  • 大多數情況:保持 _source 啟用,不需要設置 store: true
  • 禁用 _source:對需要檢索的字段設置 store: true
  • 性能優化:當文檔很大但只需要少量字段時,可考慮存儲特定字段。
  • 注意:存儲字段會增加索引大小,應謹慎使用。

3.2 實際應用示例

PUT news_articles
{"mappings": {"_source": {"enabled": true},"properties": {"headline": {"type": "text","store": true},"body": {"type": "text"},"publish_date": {"type": "date","store": true}}}
}

這樣設計可以:

  • 通過 _source 獲取完整文章內容。
  • 快速單獨訪問 headlinepublish_date 字段(如用于列表展示)。
  • body 內容只通過 _source 獲取,減少存儲開銷。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86360.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86360.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86360.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

新建網站部署流程

1. 新建 Node 服務,指定端口并代理前端靜態資源 操作步驟: 初始化 Node 項目mkdir my-website && cd my-website npm init -y npm install express創建 app.js(示例代碼)const express require(express); const app e…

時序數據庫IoTDB結合SeaTunnel實現高效數據同步

益、基本概念介紹 1.1 Apache IoTDB Apache IoTDB是一款專為工業物聯網設計的時序數據庫管理系統,集數據收集、存儲、管理與分析于一體,滿足海量數據存儲、高速讀取及復雜數據分析需求。其架構包括時序文件(TsFile)、數據庫引擎…

k8s業務程序聯調工具-KtConnect

概述 原理 工具作用是建立了一個從本地到集群的單向VPN,根據VPN原理,打通兩個內網必然需要借助一個公共中繼節點,ktconnect工具巧妙的利用k8s原生的portforward能力,簡化了建立連接的過程,apiserver間接起到了中繼節…

RFID推動新能源汽車零部件生產系統管理應用案例

RFID推動新能源汽車零部件生產系統管理應用案例 一、項目背景 新能源汽車零部件場景 在新能源汽車零部件生產領域,電子冷卻水泵等關鍵部件的裝配溯源需求日益增長。傳統 RFID 溯源方案采用 “網關 RFID 讀寫頭” 模式,存在單點位單獨頭溯源、網關布線…

C#封裝HttpClient:HTTP請求處理最佳實踐

C#封裝HttpClient:HTTP請求處理最佳實踐 在現代的.NET應用程序開發中,與外部服務進行HTTP通信是一項常見需求。HttpClient作為.NET框架中處理HTTP請求的核心組件,為我們提供了強大而靈活的API。然而,直接使用原生的HttpClient可能…

【Redis/2】核心特性、應用場景與安裝配置

文章目錄 一、初識 Redis1.1 Redis 概述1. Redis 簡介2. Redis 的發展歷程 1.2 Redis 核心特性1. 高性能2. 豐富的數據類型3. 持久化4. 原子操作5. 主從復制6. 高可用性與分布式7. 內存存儲與低延遲8. 靈活的過期策略9. 事務支持10. 簡單的 API總結 1.3 Redis 應用場景Redis 適…

AI大模型在測試領域應用案例拆解:AI賦能的軟件測試效能躍遷的四大核心引擎(順豐科技)

導語 5月份QECon深圳大會已經結束,繼續更新一下案例拆解,本期是來自順豐科技。 文末附完整版材料獲取方式。 首先來看一下這個案例的核心內容,涵蓋了測四用例設計、CI/CD輔助、測試執行、監控預警四大方面,也是算大家比較熟悉的…

【HTML】HTML 與 CSS 基礎教程

作為 Java 工程師,掌握 HTML 和 CSS 也是需要的,它能讓你高效與前端團隊協作、調試頁面元素,甚至獨立完成簡單頁面開發。本文將用最簡潔的方式帶你掌握核心概念。 一、HTML,網頁骨架搭建 核心概念:HTML通過標簽定義內…

Redis 集群批量刪除key報錯 CROSSSLOT Keys in request don‘t hash to the same slot

Redis 集群報錯 CROSSSLOT Keys in request dont hash to the same slot 的原因及解決方案 1. 錯誤原因 在 Redis 集群模式下,數據根據 哈希槽(Slot) 分散存儲在不同的節點上(默認 16384 個槽)。當執行涉及多個 key …

.Net Framework 4/C# LINQ*

一、什么是 LINQ LINQ 是一種在 C# 等編程語言中集成的查詢功能,它允許開發者使用編程語言本身的語法進行數據查詢,而不是嵌入式的字符串 SQL 語句。LINQ 查詢可以應用于對象、XML 和數據庫等多種數據源。 二、LINQ 查詢的基本構成 LINQ 查詢通常包含以…

【docker】容器技術如何改變軟件開發與部署格局

在當今數字化時代,軟件開發與部署的效率和靈活性至關重要。就像古人云:“工欲善其事,必先利其器。”Docker 作為一款強大的容器技術,正如同軟件開發領域的一把利器,極大地改變了應用的開發、交付和運行方式。本文將深入…

MySQL的優化部分介紹

1、定期維護表: ANALYZE TABLE t_order_package; OPTIMIZE TABLE t_order_package; -- 每月在低峰期執行 2、數據歸檔(如果create_time較舊): -- 歸檔舊數據到歷史表 INSERT INTO t_order_package_archive SELECT * FROM t_or…

Go基本語法——go語言中的四種變量定義方法

前言 在go語言中,定義一個變量有四種方式,本文單從語法的層面來介紹這幾種方式 單變量定義方法 1.var 變量名 類型,不進行初始化 例如,定義一個變量a后為其賦值,并且打印其值,運行結果如下 //1.不進行…

C++ 對 C 的兼容性

C 對 C 語言的兼容性是有限且有條件的,并非完全無縫兼容。這種兼容性主要體現在語法、標準庫和運行時特性上,但存在一些關鍵差異和不兼容點。以下是詳細分析: 一、C 對 C 的兼容性表現 1. 語法兼容:大部分 C 代碼可直接編譯 基…

ES6 核心語法手冊

ES6 核心語法手冊 一、變量聲明 關鍵字作用域是否可重定義是否可修改特性let塊級作用域??替代 var 的首選const塊級作用域??聲明常量(對象屬性可修改) // 示例 let name "Alice"; name "Bob"; // ?const PI 3.14; // PI …

react菜單,動態綁定點擊事件,菜單分離出去單獨的js文件,Ant框架

1、菜單文件treeTop.js // 頂部菜單 import { AppstoreOutlined, SettingOutlined } from ant-design/icons; // 定義菜單項數據 const treeTop [{label: Docker管理,key: 1,icon: <AppstoreOutlined />,url:"/docker/index"},{label: 權限管理,key: 2,icon:…

gRPC協議

目錄 1. gRPC協議介紹及構成 協議分層 協議關鍵字段 2. 示例&#xff1a;Greeter 服務 步驟1&#xff1a;定義 .proto 文件 步驟2&#xff1a;生成代碼 3. Java代碼示例 依賴配置&#xff08;Maven pom.xml&#xff09; 服務端實現 客戶端實現 運行流程 關鍵機制 …

深度學習 w b

在深度學習中&#xff0c;權重 w 和 偏置 b 是神經網絡的核心參數&#xff0c;它們的形態&#xff08;shape&#xff09;取決于網絡結構和數據維度。以下是關于 w 和 b 的詳細解析&#xff1a; 1. 數學表示與物理意義 權重 w&#xff1a; 連接神經元之間的強度&#xff0c;決定…

el-table 樹形數據,子行數據可以異步加載

1、 <el-tableborder:header-cell-style"tableStyle?.headerCellStyle"ref"tableRef":data"tableData"row-key"id":default-expand-all"false" // 默認不展開所有樹形節點:tree-props"{ children: children, hasC…

Vue中渲染函數的使用

Vue中渲染函數的使用 1. render函數2. h()的使用3. render函數和h函數的區分 vue中的渲染函數&#xff1a; 1.template2.render函數3.jsx -> js extension(jsx也是編譯成render函數&#xff0c;可編程能力更強) 1. render函數 1.1. 認識h函數 1.1.1. Vue推薦在絕大多數情況…