引言
一般情況下,會考慮到MySQL與MongoDB如何做技術選型的時候,你一定是遇到了類似于非結構化數據JSON的存取難題,否則大家都直接MySQL開始搞起了。
為什么要關注MongoDB呢?
下圖是DB-Engines 2023年10月數據庫的排名統計,可以看到MongoDB總排名在第5,在Nosql數據庫中排名第1。
圖片
既然要做技術選型,那就先要弄明白其中的一些區別和差異。
一、什么是MySQL?
MySQL是一個關系型數據庫管理系統,由瑞典MySQL AB 公司開發,屬于 Oracle 旗下產品。MySQL是最流行的關系型數據庫管理系統之一,在 WEB 應用方面,MySQL是最好的RDBMS (Relational Database Management System,關系數據庫管理系統)應用軟件之一。
主要特點:
1、強大的體系結構
2、集群架構的多樣性
3、完整的復制體系
4、強大的多行事務的支持
5、不同的插件式存儲引擎的支持(InnoDB)
6、第三方工具種類豐富,社區用戶活躍
二、什么是MongoDB?
MongoDB 是一個基于分布式文件存儲的數據庫。由C++語言編寫,旨在為WEB應用提供可擴展的高性能數據存儲解決方案。
MongoDB將數據存儲為一個文檔,數據結構由鍵值(key=>value)對組成。MongoDB文檔類似于JSON 對象。字段值可以包含其他文檔,數組及文檔數組。
主要特點:
1、文檔模式,無結構化數據,靈活的數據結構,適合快速開發,迭代場景
2、功能強大,位置索引、文本索引、TTL索引
3、副本集自動切換,保證數據的高可靠,服務的高可用性。
4、自動分片,存儲容量、服務能力橫向能力
5、適應于物流,物聯網等海量數據場景
6、aggregation & mapreduce
三、MongoDB與MySQL之間的差異
3.1 相關概念及術語的差異
圖片
3.2 存儲數據結構的差異
MySQL 的存儲結構分為5 級:表空間、段、簇、頁、行。表空間可以看做是InnoDB 存儲引擎邏輯結構的最高層,所有的數據都存放在表空間中。
MySQL 不同引擎有不同的存儲方式,而 MongoDB 以類JSON的文檔的格式存儲。
圖片
3.3 增刪改查操作的差異
當從數據庫表或表組合中請求信息時,MySQL 使用 結構化查詢語言(SQL),SQL是最流行和利用最廣泛的查詢語言,大多數開發人員都有這方面的經驗。
相反,MongoDB 則使用非結構化查詢語言(MQL)。要從JSON文檔數據庫請求數據或信息,首先必須指定具有結果應匹配的屬性的文檔。
盡管 MQL 和 SQL 有相似之處,但 MQL 通常需要額外花費精力進行學習。
圖片
3.4 事務支持的差異
當應用程序類型需要多行事務時,關系數據庫是最合適的選擇。除了提供安全性,MySQL還實現了高事務處理率。而 MongoDB 僅支持單文檔事務操作,弱一致性。
圖片
3.5 性能測試總結分析
- 插入速度總結:MongoDB不指定_id插入 > MySQL不指定主鍵插入 > MySQL指定主鍵插入 > MongoDB指定_id插入。
- MongoDB在指定_id插入的時候,插入性能下降非常厲害。
- MySQL非常穩定,無論在指定主鍵還是在不指定主鍵插入的情況下,其效率都差不了。
- MongoDB會充分利用內存作為緩存。
3.6 其他主要差異
接下來,我們將介紹一些其他主要差異。
圖片
四、應用場景分析
作為文檔數據庫,由于MongoDB并不限制用戶存儲數據的體量和類型,因此適合大數據的應用環境。而得益于MongoDB的水平可擴展能力,以及與云服務的敏捷性結合,它不但能夠減少開發者的工作量,簡化業務與項目的擴展流程,還能夠提供高可用性和數據的快速恢復。
不過,MongoDB在數據的可靠性、一致性、以及安全性等方面,不如MySQL。此外,當應用程序需要提供多行事務(如,會計和銀行系統)時,以MySQL為首的關系型數據庫提供了高事務處理率(high transaction rate)。實際上,與MySQL專注于提供事務的ACID和安全性不同的是,MongoDB更專注于提供高插入率(high insert rate)。
MongoDB 的應用已經滲透到各個領域,比如游戲、物流、電商、內容管理、社交、物聯網、視頻直播等。
圖片
總結
綜上所述,MySQL是一個開放源代碼的關系數據庫,這意味著它的數據被組織成表格,使您可以將數據與數據庫的其他部分相關聯。MongoDB也是開源的,但是,它是一個文檔數據庫。因此,它不關聯記錄,并且其數據模式是不固定的,從而允許具有更高插入能力的更具動態性和靈活性的數據庫。
圖片
在確定最佳數據庫系統之前,應明確并確定特定業務或項目的優先級。
- MongoDB比MySQL更能處理大量數據
- 因此,對于基于云的服務,易于增長和更改的應用程序以及數據量大的環境,它是最合適的選擇。
- 相反,MySQL的固定和結構化數據模式提供了比大多數數據庫更高的一致性和可靠性。
- 使用MySQL的另一個巨大好處是,由于符合ACID的事務而具有卓越的數據安全性,是重視此功能的應用程序的最合適選擇。
總之,MongoDB和MySQL都很優秀,具體如何選擇,完全取決于您的具體應用需求和系統特征。