11-1 Firebase 資料庫簡介
NoSQL 資料庫觀念
11-1-1 NoSQL 資料庫觀念
資料主體是資料項,每筆資料皆是
key-value
對應關係。資料庫類型
Wide Column Store / Column Families
Document Store
Key Value / Tuple Store
Graph Database Management Systems
Multimodel Database Management Systems
RDBMS 與 NoSQL 差異
RDBMS
NoSQL
資料相依性
關聯式
狀態性
應用面
高邏輯
非邏輯
擴充性
垂直擴充
水平擴充
理論性目標
ACID
CAP
CAP 理論概要
CAP 定義如下: C: Consistency 一致性 A: Availability 可用性 P: Partition Tolerance分區容錯性
CAP理論的核心是:一個分布式系統不可能同時很好的滿足一致性,可用性和分區容錯性這三個需求,最多只能同時較好的滿足兩個。
NoSQL 受到CAP理論的約束,不可能達到高一致性,高可用性,高分區容錯性的完美設計。所以我們在設計的時候要懂得取舍,重點關注對應用需求來說比較重要的,而放棄不重要的,在CAP這三者之間進行取舍,設計出貼合應用的存儲方案。 資料轉載\來源連結
轉載文章:換 NoSQL 前的建議...
文章來源連結 重點摘要:
其實 SQL 可以解決大部分的事情,大家都知道 SQL 的瓶頸在哪裡,有哪些 workaround 可以避開。
不要因為 MySQL 做不到就覺得 SQL 不好用,在這種情況下,PostgreSQL 的功能與成熟度很值得看看。
不要用 Oracle 官方版本的 MySQL... XD
通常可以用 cache 解決的就用 cache 試著解看看,雖然 invalidate 問題不太好處哩... XD
如果是 Read 數量太多,可以用 replication 解決不少問題。
試著去理解 index 的「原理」,也就是資料結構,這對於要怎麼用 index 絕對有強力的幫助。
當上面都做完而發現還是不夠的時候就 sharding 吧。
課本實做筆記
debug 筆記
出現錯誤1: python 2.7
解法
出現錯誤2: python 3.8
解法
Last updated