NoSQL 運動給數(shù)據(jù)庫系統(tǒng)留下什么寶貴的思想?
一、NoSQL 運動給數(shù)據(jù)庫系統(tǒng)留下什么寶貴的思想
如果非要給NoSQL一個歷史定位的話,那應該是一次對關系型數(shù)據(jù)庫的解構運動。
這次解構運動的發(fā)起是由于互聯(lián)網(wǎng)應用的興起,由于互聯(lián)網(wǎng)對存儲的使用重規(guī)模輕邏輯,所以導致傳統(tǒng)的關系型數(shù)據(jù)庫使用成本過高。于是促長了MySQL等開源數(shù)據(jù)庫的發(fā)展和成長。對那些開源的關系型數(shù)據(jù)庫進行解構,造成了NoSQL的局面。但問題在于當時那群年輕的互聯(lián)網(wǎng)程序員沒有好好回顧數(shù)據(jù)庫的發(fā)展史,而是帶著操作系統(tǒng)(文件系統(tǒng))的包袱去解構的,再加上操作系統(tǒng)陣營和數(shù)據(jù)庫陣營歷來的對壘,導致了這場不應該發(fā)生的重復造輪子運動。
如果對數(shù)據(jù)庫內核開發(fā)了解的同學應該知道,所有關系型數(shù)據(jù)庫都是從鍵值數(shù)據(jù)庫發(fā)展起來的,數(shù)據(jù)存儲引擎最底層都是一個鍵值數(shù)據(jù)庫。還有現(xiàn)在流行的各種消息中間件(RABBIT MQ之流)也是關系數(shù)據(jù)庫中的一個零件而已(connection),是在網(wǎng)絡興起后,數(shù)據(jù)庫提供CS架構下誕生的遠程訪問方案。所以就像一個小男孩喜歡拆玩具車,把電動機拿下來單獨轉;把輪子拆下來單獨滾,自得其樂。
如果非要說留下什么寶貴思想,那就是當你覺得要做一件了不起的事情時,先查一下歷史,也許已經有人淌過了,你就別再攪混水了。不過好像沒什么卵用,歷史總是不斷的重復,這不“無/低代碼”運動又來了。
延伸閱讀:
二、數(shù)據(jù)庫的查詢功能實現(xiàn)原理
數(shù)據(jù)庫查詢是數(shù)據(jù)庫的最主要功能之一。我們都希望查詢數(shù)據(jù)的速度能盡可能的快,因此數(shù)據(jù)庫系統(tǒng)的設計者會從查詢算法的角度進行優(yōu)化。最基本的查詢算法當然是順序查找(linear search),這種復雜度為O(n)的算法在數(shù)據(jù)量很大時顯然是糟糕的,好在計算機科學的發(fā)展提供了很多更優(yōu)異的查找算法,例如二分查找(binary search)、二叉樹查找(binary tree search)等。如果稍微分析一下會發(fā)現(xiàn),每種查找算法都只能應用于特定的數(shù)據(jù)結構之上,例如二分查找要求被檢索數(shù)據(jù)有序,而二叉樹查找只能應用于二叉查找樹上,但是數(shù)據(jù)本身的組織結構不可能完全滿足各種數(shù)據(jù)結構(例如,理論上不可能同時將兩列都按順序進行組織),所以,在數(shù)據(jù)之外,數(shù)據(jù)庫系統(tǒng)還維護著滿足特定查找算法的數(shù)據(jù)結構,這些數(shù)據(jù)結構以某種方式引用(指向)數(shù)據(jù),這樣就可以在這些數(shù)據(jù)結構上實現(xiàn)高級查找算法。這種數(shù)據(jù)結構,就是索引。

猜你喜歡LIKE
相關推薦HOT
更多>>
mysql怎么查看連接池是否已滿?
一、mysql怎么查看連接池是否已滿1.查看連接數(shù)配置(MySQL服務器允許的最大連接數(shù)16384)show variables like ‘%max_connections%’2.查看當前...詳情>>
2023-10-17 21:20:19
什么是職場情商,如何提高?
什么是情商?情商是一個 20 世紀 90 年代作為學術話題出現(xiàn)的概念,并迅速成為商業(yè)心理學和職場動態(tài)研究的重要組成部分。它通常被稱為 EQ(情商...詳情>>
2023-10-17 20:16:30
vector, list, map等容器使用場合是什么?
一、vector, list, map等容器使用場合vector適用于對象簡單,變化較小,并且頻繁隨機訪問的場景。list適用經常進行插入和刪除并且不經常隨機訪...詳情>>
2023-10-17 19:45:03
數(shù)據(jù)挖掘中涉及的關聯(lián)規(guī)則在實際生活中的應用有哪些?
一、數(shù)據(jù)挖掘中涉及的關聯(lián)規(guī)則在實際生活中的應用關于關聯(lián)規(guī)則分析,這篇文章可以認真學習一下,講的比較全面,關聯(lián)規(guī)則分析還在零售、快消、電...詳情>>
2023-10-17 18:40:06熱門推薦
sql server2012r2所在服務器做端口限制,需要開放什么端口才能繼續(xù)訪問數(shù)據(jù)庫?
沸Oracle有什么優(yōu)勢和劣勢?
熱數(shù)據(jù)庫聚集索引非聚集索引實現(xiàn)上有哪些區(qū)別?
熱數(shù)據(jù)庫(如oracle、mysql)及編程語言(php、python、perl、lisp)的區(qū)別?
新CSS 隱藏頁面元素有哪些方法?
除了cx_Oracle,python還可以通過什么方式訪問Oracle數(shù)據(jù)庫?
SQL開啟事務處理的語句 START TRANSACTION 和BEGIN TRAN的區(qū)別?
Android適配你需要學習哪些?
開發(fā)web應用,好的開發(fā)流程是怎么樣的?
為什么說Gradle是Android進階繞不去的坎?
mysql怎么查看連接池是否已滿?
WHERE中有很多IN判斷怎么提速?
軟件開發(fā)要遵循哪些事項?
有了innodb buffer pool為什么要有redis?
技術干貨







快速通道 更多>>
-
課程介紹
點擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學習費用
了解課程價格 -
優(yōu)惠活動
領取優(yōu)惠券 -
學習資源
領3000G教程 -
師資團隊
了解師資團隊 -
實戰(zhàn)項目
獲取項目源碼 -
開班地區(qū)
查看來校路線