【建議收藏】7000+字的TIDB保姆級簡介,你見過嗎

来源:https://www.cnblogs.com/jiagooushi/archive/2023/03/24/17251486.html
-Advertisement-
Play Games

TIDB簡介 什麼是TIDB TiDB 是一個分散式 NewSQL 資料庫。它支持水平彈性擴展、ACID 事務、標準 SQL、MySQL 語法和 MySQL 協議,具有數據強一致的高可用特性,是一個不僅適合 OLTP 場景還適合 OLAP 場景的混合資料庫。 TiDB 是 PingCAP 公司自主設 ...


TIDB簡介

Database of Databases - TiDB

什麼是TIDB

TiDB 是一個分散式 NewSQL 資料庫。它支持水平彈性擴展、ACID 事務、標準 SQL、MySQL 語法和 MySQL 協議,具有數據強一致的高可用特性,是一個不僅適合 OLTP 場景還適合 OLAP 場景的混合資料庫。

TiDBPingCAP 公司自主設計、研發的開源分散式關係型資料庫,是一款同時支持線上事務處理與線上分析處理 (Hybrid Transactional and Analytical Processing, HTAP)的融合型分散式資料庫產品,具備水平擴容或者縮容、金融級高可用、實時 HTAP、雲原生的分散式資料庫、相容 MySQL 5.7 協議和 MySQL 生態等重要特性。目標是為用戶提供一站式 OLTP (Online Transactional Processing)、OLAP (Online Analytical Processing)、HTAP 解決方案。TiDB 適合高可用、強一致要求較高、數據規模較大等各種應用場景。

什麼是NewSQL

資料庫發展至今已經有3代了:

  1. SQL,傳統關係型資料庫,例如 MySQL
  2. noSQL,例如 MongoDB,Redis
  3. newSQL
傳統SQL的問題

互聯網在本世紀初開始迅速發展,互聯網應用的用戶規模、數據量都越來越大,並且要求7X24小時線上。

傳統關係型資料庫在這種環境下成為了瓶頸,通常有2種解決方法:

升級伺服器硬體

雖然提升了性能,但總有天花板。

數據分片

使用分散式集群結構

對單點資料庫進行數據分片,存放到由廉價機器組成的分散式的集群里,可擴展性更好了,但也帶來了新的麻煩。

以前在一個庫里的數據,現在跨了多個庫,應用系統不能自己去多個庫中操作,需要使用資料庫分片中間件。

分片中間件做簡單的數據操作時還好,但涉及到跨庫join、跨庫事務時就很頭疼了,很多人乾脆自己在業務層處理,複雜度較高。

NoSQL 的問題

後來 noSQL 出現了,放棄了傳統SQL的強事務保證和關係模型,重點放在資料庫的高可用性和可擴展性。

優點
  • 高可用性和可擴展性,自動分區,輕鬆擴展
  • 不保證強一致性,性能大幅提升
  • 沒有關係模型的限制,極其靈活
缺點
  • 不保證強一致性,對於普通應用沒問題,但還是有不少像金融一樣的企業級應用有強一致性的需求。
  • 不支持 SQL 語句,相容性是個大問題,不同的 NoSQL 資料庫都有自己的 api 操作數據,比較複雜。
NewSQL 特性

NewSQL 提供了與 noSQL 相同的可擴展性,而且仍基於關係模型,還保留了極其成熟的 SQL 作為查詢語言,保證了ACID事務特性。

簡單來講,NewSQL 就是在傳統關係型資料庫上集成了 NoSQL 強大的可擴展性。

傳統的SQL架構設計基因中是沒有分散式的,而 NewSQL 生於雲時代,天生就是分散式架構。

NewSQL 的主要特性:
  • SQL 支持,支持複雜查詢和大數據分析。
  • 支持 ACID 事務,支持隔離級別。
  • 彈性伸縮,擴容縮容對於業務層完全透明。
  • 高可用,自動容災。
三種SQL的對比

img

TiDB怎麼來的

著名的開源分散式緩存服務 Codis 的作者,PingCAP聯合創始人& CTO ,資深 infrastructure 工程師的黃東旭,擅長分散式存儲系統的設計與實現,開源狂熱分子的技術大神級別人物。即使在互聯網如此繁榮的今天,在資料庫這片邊界模糊且不確定地帶,他還在努力尋找確定性的實踐方向。

直到 2012 年底,他看到 Google 發佈的兩篇論文,如同棱鏡般,折射出他自己內心微爍的光彩。這兩篇論文描述了 Google 內部使用的一個海量關係型資料庫 F1/Spanner ,解決了關係型資料庫、彈性擴展以及全球分佈的問題,併在生產中大規模使用。“如果這個能實現,對數據存儲領域來說將是顛覆性的”,黃東旭為完美方案的出現而興奮, PingCAP 的 TiDB 在此基礎上誕生了。

公司歷史可以參考下PingCAP

TiDB社區版和企業版

TiDB分為社區版以及企業版,企業版收費提供服務以及安全性的支持

image-20210310164537206

TIDB核心特性

水平彈性擴展

通過簡單地增加新節點即可實現 TiDB 的水平擴展,按需擴展吞吐或存儲,輕鬆應對高併發、海量數據場景

得益於 TiDB 存儲計算分離的架構的設計,可按需對計算、存儲分別進行線上擴容或者縮容,擴容或者縮容過程中對應用運維人員透明。

分散式事務支持

TiDB 100% 支持標準的 ACID 事務

金融級高可用

相比於傳統主從 (M-S) 複製方案,基於 Raft 的多數派選舉協議可以提供金融級的 100% 數據強一致性保證,且在不丟失大多數副本的前提下,可以實現故障的自動恢復 (auto-failover),無需人工介入

數據採用多副本存儲,數據副本通過 Multi-Raft 協議同步事務日誌,多數派寫入成功事務才能提交,確保數據強一致性且少數副本發生故障時不影響數據的可用性。可按需配置副本地理位置、副本數量等策略滿足不同容災級別的要求。

實時 HTAP

TiDB 作為典型的 OLTP 行存資料庫,同時兼具強大的 OLAP 性能,配合 TiSpark,可提供一站式 HTAP 解決方案,一份存儲同時處理 OLTP & OLAP 無需傳統繁瑣的 ETL 過程

提供行存儲引擎 TiKV、列存儲引擎 TiFlash 兩款存儲引擎,TiFlash 通過 Multi-Raft Learner 協議實時從 TiKV 複製數據,確保行存儲引擎 TiKV 和列存儲引擎 TiFlash 之間的數據強一致。TiKV、TiFlash 可按需部署在不同的機器,解決 HTAP 資源隔離的問題。

雲原生的分散式資料庫

TiDB 是為雲而設計的資料庫,同 Kubernetes 深度耦合,支持公有雲、私有雲和混合雲,使部署、配置和維護變得十分簡單。TiDB 的設計目標是 100% 的 OLTP 場景和 80% 的 OLAP 場景,更複雜的 OLAP 分析可以通過 TiSpark 項目來完成。 TiDB 對業務沒有任何侵入性,能優雅的替換傳統的資料庫中間件、資料庫分庫分表等 Sharding 方案。同時它也讓開發運維人員不用關註資料庫 Scale 的細節問題,專註於業務開發,極大的提升研發的生產力

高度相容 MySQL

相容 MySQL 5.7 協議、MySQL 常用的功能、MySQL 生態,應用無需或者修改少量代碼即可從 MySQL 遷移到 TiDB。

提供豐富的數據遷移工具幫助應用便捷完成數據遷移,大多數情況下,無需修改代碼即可從 MySQL 輕鬆遷移至 TiDB,分庫分表後的 MySQL 集群亦可通過 TiDB 工具進行實時遷移。

OLTP&OLAP(自學)

OLTP(聯機事務處理)

OLTP(Online Transactional Processing) 即聯機事務處理,OLTP 是傳統的關係型資料庫的主要應用,主要是基本的、日常的事務處理,記錄即時的增、刪、改、查,比如在銀行存取一筆款,就是一個事務交易

聯機事務處理是事務性非常高的系統,一般都是高可用的線上系統,以小的事務以及小的查詢為主,評估其系統的時候,一般看其每秒執行的Transaction以及Execute SQL的數量。在這樣的系統中,單個資料庫每秒處理的Transaction往往超過幾百個,或者是幾千個,Select 語句的執行量每秒幾千甚至幾萬個。典型的OLTP系統有電子商務系統、銀行、證券等,如美國eBay的業務資料庫,就是很典型的OLTP資料庫。

OLAP(聯機分析處理)

OLAP(Online Analytical Processing) 即聯機分析處理,是數據倉庫的核心部心,支持複雜的分析操作,側重決策支持,並且提供直觀易懂的查詢結果。典型的應用就是複雜的動態報表系統

在這樣的系統中,語句的執行量不是考核標準,因為一條語句的執行時間可能會非常長,讀取的數據也非常多。所以,在這樣的系統中,考核的標準往往是磁碟子系統的吞吐量(帶寬),如能達到多少MB/s的流量。

特性對比

OLTP和OLAP的特性對比

OLTP OLAP
實時性 OLTP 實時性要求高,OLTP 資料庫旨在使事務應用程式僅寫入所需的數據,以便儘快處理單個事務 OLAP 的實時性要求不是很高,很多應用頂多是每天更新一下數據
數據量 OLTP 數據量不是很大,一般只讀 / 寫數十條記錄,處理簡單的事務 OLAP 數據量大,因為 OLAP 支持的是動態查詢,所以用戶也許要通過將很多數據的統計後才能得到想要知道的信息,例如時間序列分析等等,所以處理的數據量很大
用戶和系統的面向性 OLTP 是面向顧客的,用於事務和查詢處理 OLAP 是面向市場的,用於數據分析
資料庫設計 OLTP 採用實體 - 聯繫 ER 模型和麵嚮應用的資料庫設計 OLAP 採用星型或雪花模型和麵向主題的資料庫設計
設計角度區別
OLTP OLAP
用戶 操作人員,低層管理人員 決策人員,高級管理人員
功能 日常操作處理 分析決策
主要工作 增、刪、改 查詢
DB 設計 面嚮應用 面向主題
數據 當前的,最新的細節,二維的,分立的 歷史的,聚集的,多維集成的,統一的
存取 讀/寫數十條記錄 讀上百萬條記錄
工作單位 簡單的事務 複雜的查詢
用戶數 上千個 上百個
DB 大小 100MB-GB 100GB-TB

TiDB 整體架構

TiDB的優勢

與傳統的單機資料庫相比,TiDB 具有以下優勢:

  • 純分散式架構,擁有良好的擴展性,支持彈性的擴縮容
  • 支持 SQL,對外暴露 MySQL 的網路協議,並相容大多數 MySQL 的語法,在大多數場景下可以直接替換 MySQL
  • 預設支持高可用,在少數副本失效的情況下,資料庫本身能夠自動進行數據修複和故障轉移,對業務透明
  • 支持 ACID 事務,對於一些有強一致需求的場景友好,例如:銀行轉賬
  • 具有豐富的工具鏈生態,覆蓋數據遷移、同步、備份等多種場景

TiDB的組件

要深入瞭解 TiDB 的水平擴展和高可用特點,首先需要瞭解 TiDB 的整體架構。TiDB 集群主要包括三個核心組件:TiDB Server,PD Server 和 TiKV Server,此外,還有用於解決用戶複雜 OLAP 需求的 TiSpark 組件。

在內核設計上,TiDB 分散式資料庫將整體架構拆分成了多個模塊,各模塊之間互相通信,組成完整的 TiDB 系統。對應的架構圖如下:

architecture

TiDB Server

TiDB Server 負責接收 SQL 請求,處理 SQL 相關的邏輯,並通過 PD 找到存儲計算所需數據的 TiKV 地址,與 TiKV 交互獲取數據,最終返回結果。TiDB Server 是無狀態的,其本身並不存儲數據,只負責計算,可以無限水平擴展,可以通過負載均衡組件(如 LVS、HAProxy 或 F5)對外提供統一的接入地址。

PD (Placement Driver) Server

Placement Driver (簡稱 PD) 是整個集群的管理模塊,其主要工作有三個:

  • 一是存儲集群的元信息(某個 Key 存儲在哪個 TiKV 節點);
  • 二是對 TiKV 集群進行調度和負載均衡(如數據的遷移、Raft group leader 的遷移等);
  • 三是分配全局唯一且遞增的事務 ID。

PD 通過 Raft 協議保證數據的安全性。Raft 的 leader server 負責處理所有操作,其餘的 PD server 僅用於保證高可用。建議部署奇數個 PD 節點

TiKV Server

TiKV Server 負責存儲數據,從外部看 TiKV 是一個分散式的提供事務的 Key-Value 存儲引擎。存儲數據的基本單位是 Region,每個 Region 負責存儲一個 Key Range(從 StartKey 到 EndKey 的左閉右開區間)的數據,每個 TiKV 節點會負責多個 Region。TiKV 使用 Raft 協議做複製,保持數據的一致性和容災。副本以 Region 為單位進行管理,不同節點上的多個 Region 構成一個 Raft Group,互為副本。數據在多個 TiKV 之間的負載均衡由 PD 調度,這裡也是以 Region 為單位進行調度。

TiSpark

TiSpark 作為 TiDB 中解決用戶複雜 OLAP 需求的主要組件,將 Spark SQL 直接運行在 TiDB 存儲層上,同時融合 TiKV 分散式集群的優勢,並融入大數據社區生態。至此,TiDB 可以通過一套系統,同時支持 OLTP 與 OLAP,免除用戶數據同步的煩惱。

TiFlash

TiFlash 是一類特殊的存儲節點。和普通 TiKV 節點不一樣的是,在 TiFlash 內部,數據是以列式的形式進行存儲,主要的功能是為分析型的場景加速。

TiKV整體架構

與傳統的整節點備份方式不同的,TiKV是將數據按照 key 的範圍劃分成大致相等的切片(下文統稱為 Region),每一個切片會有多個副本(通常是 3 個),其中一個副本是 Leader,提供讀寫服務。TiKV 通過 PD 對這些 Region 以及副本進行調度,以保證數據和讀寫負載都均勻地分散在各個 TiKV 上,這樣的設計保證了整個集群資源的充分利用並且可以隨著機器數量的增加水平擴展。

storage-architecture

Region分裂與合併

當某個 Region 的大小超過一定限制(預設是 144MB)後,TiKV 會將它分裂為兩個或者更多個 Region,以保證各個 Region 的大小是大致接近的,這樣更有利於 PD 進行調度決策。同樣,當某個 Region 因為大量的刪除請求導致 Region 的大小變得更小時,TiKV 會將比較小的兩個相鄰 Region 合併為一個。

Region調度

Region 與副本之間通過 Raft 協議來維持數據一致性,任何寫請求都只能在 Leader 上寫入,並且需要寫入多數副本後(預設配置為 3 副本,即所有請求必須至少寫入兩個副本成功)才會返回客戶端寫入成功。

當 PD 需要把某個 Region 的一個副本從一個 TiKV 節點調度到另一個上面時,PD 會先為這個 Raft Group 在目標節點上增加一個 Learner 副本(複製 Leader 的數據)。當這個 Learner 副本的進度大致追上 Leader 副本時,Leader 會將它變更為 Follower,之後再移除操作節點的 Follower 副本,這樣就完成了 Region 副本的一次調度。

Leader 副本的調度原理也類似,不過需要在目標節點的 Learner 副本變為 Follower 副本後,再執行一次 Leader Transfer,讓該 Follower 主動發起一次選舉成為新 Leader,之後新 Leader 負責刪除舊 Leader 這個副本。

分散式事務

TiKV 支持分散式事務,用戶(或者 TiDB)可以一次性寫入多個 key-value 而不必關心這些 key-value 是否處於同一個數據切片 (Region) 上,TiKV 通過兩階段提交保證了這些讀寫請求的 ACID 約束。

高可用架構

高可用是 TiDB 的另一大特點,TiDB/TiKV/PD 這三個組件都能容忍部分實例失效,不影響整個集群的可用性。下麵分別說明這三個組件的可用性、單個實例失效後的後果以及如何恢復。

TiDB高可用

TiDB 是無狀態的,推薦至少部署兩個實例,前端通過負載均衡組件對外提供服務。當單個實例失效時,會影響正在這個實例上進行的 Session,從應用的角度看,會出現單次請求失敗的情況,重新連接後即可繼續獲得服務。單個實例失效後,可以重啟這個實例或者部署一個新的實例。

PD高可用

PD 是一個集群,通過 Raft 協議保持數據的一致性,單個實例失效時,如果這個實例不是 Raft 的 leader,那麼服務完全不受影響;如果這個實例是 Raft 的 leader,會重新選出新的 Raft leader,自動恢復服務。PD 在選舉的過程中無法對外提供服務,這個時間大約是3秒鐘。推薦至少部署三個 PD 實例,單個實例失效後,重啟這個實例或者添加新的實例。

TiKV高可用

TiKV 是一個集群,通過 Raft 協議保持數據的一致性(副本數量可配置,預設保存三副本),並通過 PD 做負載均衡調度。單個節點失效時,會影響這個節點上存儲的所有 Region。對於 Region 中的 Leader 結點,會中斷服務,等待重新選舉;對於 Region 中的 Follower 節點,不會影響服務。當某個 TiKV 節點失效,並且在一段時間內(預設 10 分鐘)無法恢復,PD 會將其上的數據遷移到其他的 TiKV 節點上。

應用場景

MySQL分片與合併

img

![img](file:///D:/%E6%96%87%E6%A1%A3/%E4%BC%A0%E6%99%BA%E6%92%AD%E5%AE%A2/%E6%9E%B6%E6%9E%84%E5%B8%88/%E8%AF%BE%E7%A8%8B%E8%B5%84%E6%96%99/%E6%96%B0%E8%AF%BE%E8%AE%BE%E8%AE%A1/TiDB%E4%BA%BF%E7%BA%A7%E8%AE%A2%E5%8D%95%E6%95%B0%E6%8D%AE%E4%BA%9A%E7%A7%92%E5%93%8D%E5%BA%94%E6%9F%A5%E8%AF%A2%E6%96%B9%E6%A1%88/images/tidb69.png)

TiDB 應用的第一類場景是 MySQL 的分片與合併。對於已經在用 MySQL 的業務,分庫、分表、分片、中間件是常用手段,隨著分片的增多,跨分片查詢是一大難題。TiDB 在業務層相容 MySQL 的訪問協議,PingCAP 做了一個數據同步的工具——Syncer,它可以把黃東旭 TiDB 作為一個 MySQL Slave,將 TiDB 作為現有資料庫的從庫接在主 MySQL 庫的後方,在這一層將數據打通,可以直接進行複雜的跨庫、跨表、跨業務的實時 SQL 查詢。黃東旭提到,“過去的資料庫都是一主多從,有了 TiDB 以後,可以反過來做到多主一從。”

直接替換MySQL

img

第二類場景是用 TiDB 直接去替換 MySQL。如果你的IT架構在搭建之初並未考慮分庫分表的問題,全部用了 MySQL,隨著業務的快速增長,海量高併發的 OLTP 場景越來越多,如何解決架構上的弊端呢?

在一個 TiDB 的資料庫上,所有業務場景不需要做分庫分表,所有的分散式工作都由資料庫層完成。TiDB 相容 MySQL 協議,所以可以直接替換 MySQL,而且基本做到了開箱即用,完全不用擔心傳統分庫分表方案帶來繁重的工作負擔和複雜的維護成本,友好的用戶界面讓常規的技術人員可以高效地進行維護和管理。另外,TiDB 具有 NoSQL 類似的擴容能力,在數據量和訪問流量持續增長的情況下能夠通過水平擴容提高系統的業務支撐能力,並且響應延遲穩定。

數據倉庫

img

![img](file:///D:/%E6%96%87%E6%A1%A3/%E4%BC%A0%E6%99%BA%E6%92%AD%E5%AE%A2/%E6%9E%B6%E6%9E%84%E5%B8%88/%E8%AF%BE%E7%A8%8B%E8%B5%84%E6%96%99/%E6%96%B0%E8%AF%BE%E8%AE%BE%E8%AE%A1/TiDB%E4%BA%BF%E7%BA%A7%E8%AE%A2%E5%8D%95%E6%95%B0%E6%8D%AE%E4%BA%9A%E7%A7%92%E5%93%8D%E5%BA%94%E6%9F%A5%E8%AF%A2%E6%96%B9%E6%A1%88/images/tidb72.png)

TiDB 本身是一個分散式系統,第三種使用場景是將 TiDB 當作數據倉庫使用。TPC-H 是數據分析領域的一個測試集,TiDB 2.0 在 OLAP 場景下的性能有了大幅提升,原來只能在數據倉庫裡面跑的一些複雜的 Query,在 TiDB 2.0 裡面跑,時間基本都能控制在 10 秒以內。當然,因為 OLAP 的範疇非常大,TiDB 的 SQL 也有搞不定的情況,為此 PingCAP 開源了 TiSpark,TiSpark 是一個 Spark 插件,用戶可以直接用 Spark SQL 實時地在 TiKV 上做大數據分析。

作為其他系統的模塊

img

TiDB 是一個傳統的存儲跟計算分離的項目,其底層的 Key-Value 層,可以單獨作為一個 HBase 的 Replacement 來用,它同時支持跨行事務。TiDB 對外提供兩個 API 介面,一個是 ACID Transaction 的 API,用於支持跨行事務;另一個是 Raw API,它可以做單行的事務,換來的是整個性能的提升,但不提供跨行事務的 ACID 支持。用戶可以根據自身的需求在兩個 API 之間自行選擇。例如有一些用戶直接在 TiKV 之上實現了 Redis 協議,將 TiKV 替換一些大容量,對延遲要求不高的 Redis 場景。

應用案例

img

TiDB與MySQL相容性對比

  • TiDB支持MySQL傳輸協議及其絕大多數的語法。這意味著您現有的MySQL連接器和客戶端都可以繼續使用。 大多數情況下您現有的應用都可以遷移至 TiDB,無需任何代碼修改。
  • 當前TiDB伺服器官方支持的版本為MySQL 5.7。大部分MySQL運維工具(如PHPMyAdmin, Navicat, MySQL Workbench等),以及備份恢復工具(如 mysqldump, Mydumper/myloader)等都可以直接使用。
  • 不過一些特性由於在分散式環境下沒法很好的實現,目前暫時不支持或者是表現與MySQL有差異
  • 一些MySQL語法在TiDB中可以解析通過,但是不會做任何後續的處理,例如Create Table語句中Engine,是解析並忽略。

TiDB不支持的MySql特性

  • 存儲過程與函數
  • 觸發器
  • 事件
  • 自定義函數
  • 外鍵約束
  • 臨時表
  • 全文/空間函數與索引
  • ascii/latin1/binary/utf8/utf8mb4 的字元集
  • SYS schema
  • MySQL 追蹤優化器
  • XML 函數
  • X-Protocol
  • Savepoints
  • 列級許可權
  • XA 語法(TiDB 內部使用兩階段提交,但並沒有通過 SQL 介面公開)
  • CREATE TABLE tblName AS SELECT stmt 語法
  • CHECK TABLE 語法
  • CHECKSUM TABLE 語法
  • GET_LOCKRELEASE_LOCK 函數

自增ID

TiDB 的自增列僅保證唯一,也能保證在單個 TiDB server 中自增,但不保證多個 TiDB server 中自增,不保證自動分配的值的連續性,建議不要將預設值和自定義值混用,若混用可能會收 Duplicated Error 的錯誤信息。

TiDB 可通過 tidb_allow_remove_auto_inc 系統變數開啟或者關閉允許移除列的 AUTO_INCREMENT 屬性。刪除列屬性的語法是:alter table modifyalter table change

TiDB 不支持添加列的 AUTO_INCREMENT 屬性,移除該屬性後不可恢復。

SELECT 的限制

  • 不支持 SELECT ... INTO @變數 語法。
  • 不支持 SELECT ... GROUP BY ... WITH ROLLUP 語法。
  • TiDB 中的 SELECT .. GROUP BY expr 的返回結果與 MySQL 5.7 並不一致。MySQL 5.7 的結果等價於 GROUP BY expr ORDER BY expr。而 TiDB 中該語法所返回的結果並不承諾任何順序,與 MySQL 8.0 的行為一致。

視圖

目前TiDB不支持對視圖進行UPDATE、INSERT、DELETE等寫入操作

預設設置差異

字元集
  • TiDB 預設:utf8mb4
  • MySQL 5.7 預設:latin1
  • MySQL 8.0 預設:utf8mb4
排序規則
  • TiDB 中 utf8mb4 字元集預設:utf8mb4_bin
  • MySQL 5.7 中 utf8mb4 字元集預設:utf8mb4_general_ci
  • MySQL 8.0 中 utf8mb4 字元集預設:utf8mb4_0900_ai_ci
大小寫敏感

關於lower_case_table_names的配置

  • TiDB 預設:2,且僅支持設置該值為 2
  • MySQL 預設如下:
    • Linux 系統中該值為 0
    • Windows 系統中該值為 1
    • macOS 系統中該值為 2
參數解釋
  • lower_case_table_names=0 表名存儲為給定的大小和比較是區分大小寫的
  • lower_case_table_names = 1 表名存儲在磁碟是小寫的,但是比較的時候是不區分大小寫
  • lower_case_table_names=2 表名存儲為給定的大小寫但是比較的時候是小寫的
timestamp類型欄位更新

預設情況下,timestamp類型欄位所在數據行被更新時,該欄位會自動更新為當前時間,而參數explicit_defaults_for_timestamp控制這一種行為。

  • TiDB 預設:ON,且僅支持設置該值為 ON
  • MySQL 5.7 預設:OFF
  • MySQL 8.0 預設:ON
參數解釋
  • explicit_defaults_for_timestamp=off,數據行更新時,timestamp類型欄位更新為當前時間
  • explicit_defaults_for_timestamp=on,數據行更新時,timestamp類型欄位不更新為當前時間。
外鍵支持
  • TiDB 預設:OFF,且僅支持設置該值為 OFF
  • MySQL 5.7 預設:ON

本文由傳智教育博學谷狂野架構師教研團隊發佈。

如果本文對您有幫助,歡迎關註點贊;如果您有任何建議也可留言評論私信,您的支持是我堅持創作的動力。

轉載請註明出處!


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

-Advertisement-
Play Games
更多相關文章
  • 生產者消費者問題 簡介 生產者消費者模式並不是GOF提出的23種設計模式之一,23種設計模式都是建立在面向對象的基礎之上的,但其實面向過程的編程中也有很多高效的編程模式,生產者消費者模式便是其中之一,它是我們編程過程中最常用的一種設計模式。 在實際的軟體開發過程中,經常會碰到如下場景:某個模塊負責產 ...
  • 之前用過NXOpen PDM的命名空間下的類,現在記錄一下通過PDM命名空間下的類查詢Teamcenter零組件的信息,也可以用來判斷該零組件是否存在。 1-該工程為DLL工程,直接在NX界面調用,所以直接獲取NXSession。 2-查詢函數advanced用到的查詢為:__NX_STD_ANY_ ...
  • 本文已收錄至Github,推薦閱讀 👉 Java隨想錄 微信公眾號:Java隨想錄 摘要 Redis是一款性能強勁的記憶體資料庫,但是在使用過程中,我們可能會遇到Big Key問題,這個問題就是Redis中某個key的value過大,所以Big Key問題本質是Big Value問題,導致Redis ...
  • 9 月 15 日,Figma 的 CEO Dylan Field 發佈消息:今天,Figma 宣佈接受 Adobe 的收購... Adobe 以約 200 億美元收購 Figma,這也是 Adobe 該公司在其歷史上的最大一筆收購。那是什麼樣的魔力,讓 Figma 被 Adobe 收購呢?下麵以定位 ...
  • 實現Redis的database層(核心層:處理命令並返回) https://github.com/csgopher/go-redis 本文涉及以下文件: dict:定義字典的一些方法 sync_dict:實現dict db:分資料庫 command:定義指令 ping,keys,string:指令 ...
  • Antlr4 簡介 ANTLR(全名:ANother Tool for Language Recognition)是基於LL(*)演算法實現的語法解析器生成器(parser generator),用Java語言編寫,使用自上而下(top-down)的遞歸下降LL剖析器方法。由舊金山大學的Terence ...
  • 導入的文件 前端點擊上傳得到文件(MultipartFile file 【這裡是存放的臨時文件】) 本人前端用的vue3,elementui, 導入按鈕代碼 <!--導入文件 --> <el-col :span="1.5"> <el-button type="info" plain icon="el ...
  • 如題,很簡單,就是先用chardet 庫識別文件編碼,解碼之後再輸出成目標編碼。算是個偶爾能用上的小工具,要用的時候萬一沒有就很難受的那種,比如,網上下載了別人的項目文件,一打開全是亂碼…… 代碼 加了比較詳細的註釋~~ 看懂的要求應該不高,平時用過Python,知道幾個常用庫就行。 from pa ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...