資料庫系列 - 1: 儲存引擎

閱讀時間約 3 分鐘

大家好,這個系列會介紹一些資料庫相關知識與內容,目前主要會偏向架構與一些應用上的知識為主,畢竟我不是 DBA 相關的工具,因此太過詳細的細節與內容會省略。好的,那麼第一節就來介紹一下資料庫的種類,以及主要的兩種儲存引擎吧[註1]!

關聯式資料庫 v.s. 非關聯式資料庫

根據資料之間的緊密、關聯程度,我們可以選擇使用關聯式或是非關聯式資料庫。

關聯式資料庫,資料都放在一個個資料表( table )中,而資料表與資料表間通常會有某些關聯,例如 A 資料表的 a 欄位與 B 資料表的 b 欄位數值相同,那麼我們就能藉由這種關聯性去篩選出我們在不同情境下所需要的資料。截至目前為止,由於這種關聯的特性,關聯式資料庫仍舊是最常使用的,而關聯式資料庫中應用最廣的則是 MySQL 。

非關聯式資料庫,資料則存放在一個個文件( document )中,而每筆資料則是用 json 的方式記錄在裡面。相比之下,由於非關聯式資料庫的文件之間無特定關聯,因此在建立上十分方便,也不需要指定輸入的欄位[註2],因此通常用於新創公司或是新業務拓展等,這些還不確定需要哪些資料的情況,或是用於紀錄 log 這種時間到就可以刪除的資料。

MyISAM

MyISAM,是改良自傳統的 ISAM ( Indexed Sequential Access Method ),也是 MySQL 最早的 Engine,它的主要優勢在於查詢的效能以及大容量的儲存空間。

由於 MyISAM 只管理索引並 cache ,因此比起同時管理索引與資料的 InnoDB 來的快上許多。然而 MyISAM 有兩個(對現代主流來說)嚴重的缺點, 就是不支援事務處理( Transaction )[註3]以及不支援外鍵( FK )[註4]。

此外,在清空資料( Drop )以及增長資料( Auto_Increment )這件事情上,MyISAM 比 InnoDB 快上許多,因此總結來說 MyISAM 本身比較適合處理高併發的情況。

InnoDB

InnoDB 是不同於 MyISAM 的另一種類型引擎,強調的是小而巧的功能。每張表的容量上限相對較低,但是能夠操作的功能更加細緻化,例如 Transaction 以及支援 FK。

此外, InnoDB 支援行級鎖( Row-level Lock ),代表不需要再跟之前的 MyISAM 一樣將整張表鎖起來進行操作,因此在處理 Select 以外的操作也快上許多。

目前 MySQL 的預設資料庫引擎已經改為使用 InnoDB ,因此若沒有特別調整的話都是直接使用目前偏主流的 InnoDB 囉~


[註1] 資料庫引擎有非常多種,以 MySQL 為例,只要輸入 SHOW ENGINES; 就可以看到長長一排它所支援使用的引擎。

[註2] 非關聯式資料庫依舊可以設定必須填入欄位,只是並不像關聯式資料庫一樣是必須的設定。

[註3] Transaction 多用於同時處理多張表的資料,或是一次性處理同張表內大量資料時,為了確保這些資料們都能成功處理的一種方式。

[註4] FK 算是關聯式資料庫在設計時的核心,連接資料表與資料表。

參考資料:

  1. https://www.codegym.tech/blog/sql-vs-nosql
  2. https://hackmd.io/@KaiChen/HkIYIad19
  3. https://www.runoob.com/w3cnote/mysql-different-nnodb-myisam.html
  4. https://www.cnblogs.com/wzh2010/p/17794018.html
avatar-img
2會員
25內容數
test
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
林柏宇的沙龍 的其他內容
本文分享了在面試演算法工程師時經常會遇到的問題及解題方法,包括複雜度分析、五大演算法的介紹、排序方法及動態規劃等。希望這些資訊能幫助求職者在面試時有更好的準備、提高自信,並提供參考資料以便深入學習相關內容。
本文介紹正規表達式的基本概念和常用符號,幫助讀者瞭解如何使用正規表達式來有效搜尋資料和程式碼。在數位時代,正規表達式成為了數據處理和程式開發中不可或缺的工具。透過示範和範例,讀者可以快速掌握正規表達式的基本語法,並應用於實際場景。
本文將介紹 RESTful API 的基本概念、特性及其在現代 Web 開發中的重要性。探討 REST 的設計理念,包括無狀態性、資源格式和 API 接口的最佳實踐,幫助工程師瞭解如何進行有效的 API 設計。
這篇文章介紹了git常用的幾個指令,包括分支合併、重製修改、修改紀錄等。另外也提到了一個好用的小工具tig。這些指令的使用方法和技巧都有詳細介紹,可以幫助讀者更好地使用git。
這篇文章介紹了基礎的 Git 指令,對於懂得使用 Git 的開發人員來說,這些指令都是非常重要且實用的。文章詳細說明瞭每個指令的功能以及如何運用,對於想要更加熟悉 Git 指令的開發人員來說,這是一篇非常實用的文章。
這篇文章將介紹工程師使用版控和git的相關知識和技能,包括版本控制的意義和git的基本指令,以及開發流程和webhook的概念。
本文分享了在面試演算法工程師時經常會遇到的問題及解題方法,包括複雜度分析、五大演算法的介紹、排序方法及動態規劃等。希望這些資訊能幫助求職者在面試時有更好的準備、提高自信,並提供參考資料以便深入學習相關內容。
本文介紹正規表達式的基本概念和常用符號,幫助讀者瞭解如何使用正規表達式來有效搜尋資料和程式碼。在數位時代,正規表達式成為了數據處理和程式開發中不可或缺的工具。透過示範和範例,讀者可以快速掌握正規表達式的基本語法,並應用於實際場景。
本文將介紹 RESTful API 的基本概念、特性及其在現代 Web 開發中的重要性。探討 REST 的設計理念,包括無狀態性、資源格式和 API 接口的最佳實踐,幫助工程師瞭解如何進行有效的 API 設計。
這篇文章介紹了git常用的幾個指令,包括分支合併、重製修改、修改紀錄等。另外也提到了一個好用的小工具tig。這些指令的使用方法和技巧都有詳細介紹,可以幫助讀者更好地使用git。
這篇文章介紹了基礎的 Git 指令,對於懂得使用 Git 的開發人員來說,這些指令都是非常重要且實用的。文章詳細說明瞭每個指令的功能以及如何運用,對於想要更加熟悉 Git 指令的開發人員來說,這是一篇非常實用的文章。
這篇文章將介紹工程師使用版控和git的相關知識和技能,包括版本控制的意義和git的基本指令,以及開發流程和webhook的概念。
你可能也想看
Google News 追蹤
Thumbnail
※ 為什麼選擇SQLite? 安裝簡單:SQLite是一個零配置的資料庫,不需要複雜的設定和安裝過程。。 使用SQL語法。 設計選擇多元性(MySQL / SQLite):適合於小零件資料應用、嵌入式系統、物聯網設備。 ※ SQLite四大優點: 執行檔檔案很小:資料庫系統需要的磁碟空
儲存庫 (Repository) 是檔案(File)的儲存區域。 在版本控制中,儲存庫是包含所有檔案的資料夾[1]。 每次改動檔案,你都可以選擇要不要儲存。 而那些有被處存的改動,就被稱為「提交 Commit」[2]。 而當一個儲存庫有多個開發者(Developer)在貢獻,
※ 生產者和消費者模式 定義: 生產者和消費者在同一時間內共同存取某一個資料空間。生產者負責生成數據並將其放入共享空間,消費者負責從共享空間中取走數據進行處理。兩者之間互不相干,也不須互相知道對方的存在。 共同存取資料空間:生產者和消費者共享同一個資料空間。這個空間通常是緩衝區或隊列,用於在它
Thumbnail
連接器故名思議就是兩個系統之間的橋樑, 而Kafka Connect正是扮演著這樣的角色, 如圖上, 我們可以透過Kafka Connect將SQL的資料導出到Kafka並導入到MySQL。 豐富的Plugin Confluent Hub提供了各式各樣的外掛套件, 包括了MongoDB、My
Thumbnail
工具功能 (1) 彈性任意查詢檔案,如對來源目錄設定,檔案修改日期 設定,檔名特定字串或副檔名設定後,自動查出明細,並可展開至各階子目錄處理     (2) 依查詢後結果,可產出 LIST ,提供查詢結果之確認,再依此對檔案作複 (3) 可對檔案作移動,複製至別處,刪除處理,使電腦可騰出硬碟空間
Thumbnail
支援Go所有的類型儲存,且可以用原生SQL敘述與跨資料庫查詢。 映射關係 table->struct record->object field->attribute 安裝 go get github.com/astaxie/beego/orm​ go get github.com
Thumbnail
※ 基本操作:SQL 語法,SELECT, WHERE, CREATE, UPDATE, DELETE。 SELECT:從資料庫中或資料表中指定要選擇的欄位中取得資料,稱之為查詢 (query)。 ※ 語法:要由兩部分構成,第一部分是要 "拿什麼" 資料 (若有多項用逗號隔開);第二部分則為
Migration在 Laravel 中是一種用來管理資料庫結構變更的機制。它的主要目的是使開發者能夠在應用程序的不同環境中保持資料庫結構的一致性,並輕鬆地進行結構變更
本課程學習如何添加 Room 資料庫相關依賴庫配置。
Thumbnail
※ 為什麼選擇SQLite? 安裝簡單:SQLite是一個零配置的資料庫,不需要複雜的設定和安裝過程。。 使用SQL語法。 設計選擇多元性(MySQL / SQLite):適合於小零件資料應用、嵌入式系統、物聯網設備。 ※ SQLite四大優點: 執行檔檔案很小:資料庫系統需要的磁碟空
儲存庫 (Repository) 是檔案(File)的儲存區域。 在版本控制中,儲存庫是包含所有檔案的資料夾[1]。 每次改動檔案,你都可以選擇要不要儲存。 而那些有被處存的改動,就被稱為「提交 Commit」[2]。 而當一個儲存庫有多個開發者(Developer)在貢獻,
※ 生產者和消費者模式 定義: 生產者和消費者在同一時間內共同存取某一個資料空間。生產者負責生成數據並將其放入共享空間,消費者負責從共享空間中取走數據進行處理。兩者之間互不相干,也不須互相知道對方的存在。 共同存取資料空間:生產者和消費者共享同一個資料空間。這個空間通常是緩衝區或隊列,用於在它
Thumbnail
連接器故名思議就是兩個系統之間的橋樑, 而Kafka Connect正是扮演著這樣的角色, 如圖上, 我們可以透過Kafka Connect將SQL的資料導出到Kafka並導入到MySQL。 豐富的Plugin Confluent Hub提供了各式各樣的外掛套件, 包括了MongoDB、My
Thumbnail
工具功能 (1) 彈性任意查詢檔案,如對來源目錄設定,檔案修改日期 設定,檔名特定字串或副檔名設定後,自動查出明細,並可展開至各階子目錄處理     (2) 依查詢後結果,可產出 LIST ,提供查詢結果之確認,再依此對檔案作複 (3) 可對檔案作移動,複製至別處,刪除處理,使電腦可騰出硬碟空間
Thumbnail
支援Go所有的類型儲存,且可以用原生SQL敘述與跨資料庫查詢。 映射關係 table->struct record->object field->attribute 安裝 go get github.com/astaxie/beego/orm​ go get github.com
Thumbnail
※ 基本操作:SQL 語法,SELECT, WHERE, CREATE, UPDATE, DELETE。 SELECT:從資料庫中或資料表中指定要選擇的欄位中取得資料,稱之為查詢 (query)。 ※ 語法:要由兩部分構成,第一部分是要 "拿什麼" 資料 (若有多項用逗號隔開);第二部分則為
Migration在 Laravel 中是一種用來管理資料庫結構變更的機制。它的主要目的是使開發者能夠在應用程序的不同環境中保持資料庫結構的一致性,並輕鬆地進行結構變更
本課程學習如何添加 Room 資料庫相關依賴庫配置。