如何向小姐姐解釋SQL和NoSQL之間的區別

来源:https://www.cnblogs.com/phploser/archive/2019/12/01/11967713.html
-Advertisement-
Play Games

最近,在Medium上出現了一個採訪問題:如何向奶奶解釋SQL和NoSQL之間的區別。我認為作者使用自己的結構化家譜來比較sql和nosql之間的差異。寫作非常好,但是有點尷尬。面試官沒有時間聽你的話。我個人認為sql和nosql之間的區別消失了。一兩個句子無法概括,更不用說告訴奶奶了,因此,如果您 ...


  最近,在Medium上出現了一個採訪問題:如何向奶奶解釋SQL和NoSQL之間的區別。我認為作者使用自己的結構化家譜來比較sql和nosql之間的差異。寫作非常好,但是有點尷尬。面試官沒有時間聽你的話。我個人認為sql和nosql之間的區別消失了。一兩個句子無法概括,更不用說告訴奶奶了,因此,如果您真的被問到這個問題,可以選擇主要區別之一。這個比喻是好的。例如,sql是通用的,而nosql是特殊的。所以我的答案是這樣的:
  親愛的祖母,資料庫是用來存儲數據的倉庫,就像我們生活中用來存儲項目的容器一樣,但是這些容器也是通用的和特殊的。例如,塑料袋是通用容器,因為塑料袋可以容納各種東西:即可以容納糖果或鉛筆。但是我們也可以選擇一種更合適的存儲方式:糖果盒和糖果盒。糖果盒和筆筒是特殊的容器。數據和項目也可以以一般或特殊方式存儲,各有利弊。 SQL是常規資料庫,而NoSQL是特殊資料庫。這是兩者之間的區別。
  集合論與關係代數
  但是為什麼SQL是通用的?世界上有數千萬的數據結構。為什麼SQL可以滿足各種需求並且半個世紀都沒有過時?
  儘管唯一不變的是變化,但是電腦行業一直在裂變,但是一些基本的東西總是一樣,或者變化非常緩慢:JavaScript是當今世界上最流行的編程語言,至今仍堅持使用Lisp語言60年前。標準的現代操作系統Windows,OSX和Linux都來自共同的祖先Unix。
  資料庫的開發是相同的。無論形式如何變化,其本質都是圍繞集合論和關係代數設計的。基本理論決定一切。只要您掌握了軟體行業的基本數學理論,就可以掌握所有變化的規律。這是SQL永恆的秘密。文章來源:神經網路


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Red Hat Enterprise Linux是美國紅帽公司開發的商業市場導向的Linux發行版,為方便大家學習研究,整理分享歷代紅帽官方正式版鏡像給有需要的朋友們。 ...
  • 截圖工具: 其中用到了動態鏈接庫DLL技術(Dynamic Link Library)技術,鍵盤鉤子技術,游標捕獲技術,類橡皮類CRectTracker 頭文件:尾碼名為.cpp,主要是定義和聲明之類的,比如類的定義和常量定義 源文件:尾碼名為.cpp,主要是實現之類的,比如類方法的實現 資源文件: ...
  • tar是UNIX和類UNIX系統上的壓縮,備份工具, 名字來源於Tape archive--磁碟歸檔,最初的時候是用來將數據儲存,備份到磁帶上的。而今最簡單的備份方法是添加新的磁碟或者在雲端存儲,但即使是最簡單和便宜的磁碟設備和雲儲存,也應該壓縮備份數據,降低存儲空間需求和傳輸時間,linux系統默 ...
  • 背景 By 魯迅 By 高爾基 說明: 1. Kernel版本:4.14 2. ARM64處理器,Contex A53,雙核 3. 使用工具:Source Insight 3.5, Visio 1. 概述 在之前的系列文章中,分析到了 的頁框分配, 的小塊記憶體對象分配,這些分配的地址都是物理記憶體連續 ...
  • 最近要使用到 alluxio,發現網上還是有一些文檔很是不錯,現在通過這篇文章進行索引一下,進行備忘: https://edgedef.com/2017/08/17/alluxio-%E5%B0%8F%E8%B0%83/ (以為網友關於 alluxio的調研) https://www2.eecs.b ...
  • 在dlib以及face_recognition通過pip安裝成功之後(如何通過pip進行安裝,在博主的上一篇隨筆中有提及),在pycharm中無法導入。 ...
  • 近些年機器視覺應用一直是個很火的方向,想象一下機器如果能長上“眼睛”,是不是就可以做一些人類才能做的事情,因此機器視覺是人工智慧實現的一個重要基礎。痞子衡當年碩士畢業論文課題就是工業相機圖像處理相關的,算是機器視覺系統的前端核心。遙想十年以前,想要從事機器視覺系統的開發一直是比較複雜的,需要開發者有... ...
  • 如圖,這個是看視頻時,最後的作業,除了客戶端未使用select實現外,其它的要求都有簡單實現。 服務端代碼如下: 客戶端代碼還是之前的版本,沒有使用select實現: ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...