ES和MySQL概念對比

基本概念

ES和MySQL都屬于數據庫,不過各有各的特性,大致使用方法與MySQL類似并無區別。

MySQL:擅長事務持有ACID的特性,確保數據的一致性和安全。

ES:持有倒排索引,適合海量數據搜索和分析。


ES和MySQL如何保證數據的一致性

保證數據的一致性可采用雙寫來實現,在修改數據庫的適合也修改ES

// 偽代碼示例
@Transactional
public void saveOrder(Order order) {// 1. 寫MySQLmysqlMapper.insert(order); // 2. 寫ES(失敗會觸發事務回滾)esClient.index(order); 
}

如果需要做優化可以通過異步實現,比如MQ,并且還能對消息做持久化和重試或確認,進一步保證了數據的安全和一致性。


倒排索引和B+Tree有什么不同

數據庫索引采用的B+Tree存儲結構維護數據,適合單點查詢和范圍查詢

         [根節點]/      \[內部節點]  [內部節點]/    |    \ 
[葉子1]?[葉子2]?[葉子3]  # 葉子節點存儲實際數據,且雙向鏈表連接

倒排索引根據詞語來進行分類,適合搜索引擎功能

{"關鍵詞A": [文檔1_ID, 文檔2_ID, ...],  # 倒排列表(Postings List)"關鍵詞B": [文檔3_ID, 文檔5_ID, ...]
}

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

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

相關文章

【python】針對Selenium中彈框信息無法定位的問題,以下是綜合解決方案及注意事項:

一、常見原因分析 1.1 彈窗類型不匹配 若彈窗為alert,需使用driver.switch_to.alert處理; 若為confirm或prompt,同樣適用該方法。 1.2 窗口句柄切換問題 新窗口或彈窗可能開啟新句柄,需先通過driver.window_handles切換到對應句…

歐拉服務器操作系統安裝MySQL

1. 安裝MySQL服務器?? 1. 更新倉庫緩存 sudo dnf makecache2. 安裝MySQL sudo dnf install mysql-server2. 初始化數據庫? sudo mysqld --initialize --usermysql3. 啟動數據庫服務 # 啟動服務 sudo systemctl start mysqld# 設置開機自啟 sudo systemctl enable mysql…

SQLark:一款國產免費數據庫開發和管理工具

SQLark(百靈連接)是一款面向信創應用開發者的數據庫開發和管理工具,用于快速查詢、創建和管理不同類型的數據庫系統,目前可以支持達夢數據庫、Oracle 以及 MySQL。 對象管理 SQLark 支持豐富的數據庫對象管理功能,包括…

Spring Boot 中的自動配置原理

2025/4/6 向全棧工程師邁進! 一、自動配置 所謂的自動配置原理就是遵循約定大約配置的原則,在boot工程程序啟動后,起步依賴中的一些bean對象會自動的注入到IOC容器中。 在講解Spring Boot 中bean對象的管理的時候,我們注入bean對…

Mysql8配置文件

Mysql8配置文件 修改my.cnf----配置持久化鍵(persistence key)配置表名不區分大小寫 修改my.cnf----配置持久化鍵(persistence key) MySQL8初始化數據庫之前配置好這些變量值,初始化數據庫之后可能無法修改這個值。 # 服務端配置 [mysqld] ######## 數據目錄和基…

關于系統架構思考,如何設計實現系統的高可用?

緒論、系統高可用的必要性 系統高可用為了保持業務連續性保障,以及停機成本量化,比如在以前的雙十一當天如果出現宕機,那將會損失多少錢?比如最近幾年Amazon 2021年30分鐘宕機損失$5.6M。當然也有成功的案例,比如異地…

【Unity筆記】實現可視化配置的Unity按鍵輸入管理器(按下/長按/松開事件 + UnityEvent綁定)

【Unity筆記】實現可視化配置的Unity按鍵輸入管理器 適用于角色控制、技能觸發的Unity按鍵輸入系統,支持UnityEvent事件綁定、長按/松開監聽與啟用開關 一、引言 在 Unity 游戲開發中,處理鍵盤輸入是最常見的交互方式之一。尤其是角色控制、技能釋放、菜…

Fortran 中使用 C_LOC 和 C_F_POINTER 結合的方法來實現不同類型指針指向同一塊內存區域

在 Fortran 中,可以使用 C_LOC 和 C_F_POINTER 結合的方法來實現不同類型指針指向同一塊內存區域。以下是具體方法和示例: 關鍵步驟: 獲取內存地址:用 C_LOC 獲取原始數組的 C 地址。類型轉換:用 C_F_POINTER 將地址轉…

Spring Boot整合Kafka的詳細步驟

1. 安裝Kafka 下載Kafka:從Kafka官網下載最新版本的Kafka。 解壓并啟動: 解壓Kafka文件后,進入bin目錄。 啟動ZooKeeper:./zookeeper-server-start.sh ../config/zookeeper.properties。 啟動Kafka:./kafka-server-…

【含文檔+PPT+源碼】基于微信小程序的學校體育館操場預約系統的設計與實現

課程簡介: 本課程演示的是一款基于微信小程序的學校體育館操場預約系統的設計與實現,主要針對計算機相關專業的正在做畢設的學生與需要項目實戰練習的 Java 學習者。 1.包含:項目源碼、項目文檔、數據庫腳本、軟件工具等所有資料 2.帶你從…

【Leetcode-Hot100】最大子數組和

題目 解答 class Solution(object):def maxSubArray(self, nums):""":type nums: List[int]:rtype: int"""len_nums len(nums)result -1e5left_fit, right_fit 0, len_nums-1if len_nums 1:return nums[0]sum_left, sum_right 0, 0while r…

txt、Csv、Excel、JSON、SQL文件讀取(Python)

txt、Csv、Excel、JSON、SQL文件讀取(Python) txt文件讀寫 創建一個txt文件 fopen(rtext.txt,r,encodingutf-8) sf.read() f.close() print(s)open( )是打開文件的方法 text.txt’文件名 在同一個文件夾下所以可以省略路徑 如果不在同一個文件夾下 ‘…

硬件電路設計之51單片機(2)

聲明:繪制原理圖和PCB的軟件為嘉立創EDA。根據B站尚硅谷嵌入式之原理圖&PCB設計教程學習所作個人用筆記。 目錄 一、原理圖詳解 1、TypeC接口 (1)TypeC接口介紹 (2)TypeC原理圖 2、5V轉3.3V 3、單片機電源開…

kubernetes 入門篇之架構介紹

經過前段時間的學習和實踐,對k8s的架構有了一個大致的理解。 1. k8s 分層架構 架構層級核心組件控制平面層etcd、API Server、Scheduler、Controller Manager工作節點層Kubelet、Kube-proxy、CRI(容器運行時接口)、CNI(網絡插件&…

Flink CDC 出現錯誤碼 1236 和 SQL 狀態 HY000 的原因及解決方法

Flink CDC 出現錯誤碼 1236 和 SQL 狀態 HY000 的原因及解決方法 常見原因 server-id 沖突:當多個 Flink CDC 任務連接同一個 MySQL 實例,且使用了相同的 server-id 時,會導致該沖突。因為 MySQL 服務器通過 server-id 來區分不同的從服務器,如果多個 Flink CDC 任務使用相…

從PPT到PNG:Python實現的高效PPT轉圖工具

從PPT到PNG:Python實現的高效PPT轉圖工具 在日常工作中,PPT(PowerPoint)文件是我們常用的演示工具。然而,有時候我們需要將PPT的內容提取為圖片格式(如PNG)以便于展示或保存。手動將每一頁PPT保…

【開發語言】懸空指針問題

懸空指針(Dangling Pointer)是編程中常見的內存管理問題,尤其在C/C這類手動管理內存的語言中。以下是詳細解釋: 什么是懸空指針? 懸空指針是指向已經被釋放(或失效)內存的指針。這段內存可能已…

【持續更新中】常用docker服務部署指北

前言 docker是個好東西,小樹莓派上也能快速部署,方便管理環境。用這篇筆記來記錄下各種軟件的快速部署方式 準備環境 docker安裝 curl -fsSL https://get.docker.com -o get-docker.sh sh ./get-docker.shdocker鏡像源配置 一種方法是設置proxy&…

Godot學習-創建簡單動畫

文章目錄 1、準備工作Godot資源 2、創建項目3、創建結點4、創建動畫1、創建動畫2、添加軌道3、創建關鍵幀3.1 第一個關鍵幀3.2 第二個關鍵幀 5、加載后自動播放6、動畫循環7、軌道設置1、軌道更新模式2、軌跡插值3、其他屬性的關鍵幀4、編輯關鍵幀5、使用 RESET 軌道6、洋蔥皮 …

Python 爬蟲解決 GBK亂碼問題

文章目錄 前言爬取初嘗試與亂碼問題編碼知識科普UTF - 8GBKUnicode Python中的編碼轉換其他編碼補充知識GBKGB18030GB2312UTF(UCS Transfer Format)Unicode 總結 前言 在Python爬蟲的過程中,我嘗試爬取一本小說,遇到GBK亂碼問題&a…