更新時間:2023-01-14 來源:黑馬程序員 瀏覽量:
支持讀取歷史版本數(shù)據(jù), 引入了一個新的 system variable: tidb_snapshot ,這個變量是 Session 范圍有效,可以通過標(biāo)準(zhǔn)的 Set 語句修改其值。其值為文本,能夠存儲 TSO 和日期時間。TSO 即是全局授時的時間戳,是從 PD 端獲取的; 日期時間的格式可以為: “2020-10-08 16:45:26.999”,一般來說可以只寫到秒,比如”2020-10-08 16:45:26”。 當(dāng)這個變量被設(shè)置時,TiDB 會用這個時間戳建立 Snapshot(沒有開銷,只是創(chuàng)建數(shù)據(jù)結(jié)構(gòu)),隨后所有的 Select 操作都會在這個 Snapshot 上讀取數(shù)據(jù)。
注意:TiDB 的事務(wù)是通過 PD 進(jìn)行全局授時,所以存儲的數(shù)據(jù)版本也是以 PD 所授時間戳作為版本號。在生成 Snapshot 時,是以 tidb_snapshot 變量的值作為版本號,如果 TiDB Server 所在機(jī)器和 PD Server 所在機(jī)器的本地時間相差較大,需要以 PD 的時間為準(zhǔn)。
當(dāng)讀取歷史版本操作結(jié)束后,可以結(jié)束當(dāng)前 Session 或者是通過 Set 語句將 tidb_snapshot 變量的值設(shè)為 “",即可讀取最新版本的數(shù)據(jù)。
TiDB 使用 MVCC 管理版本,當(dāng)更新/刪除數(shù)據(jù)時,不會做真正的數(shù)據(jù)刪除,只會添加一個新版本數(shù)據(jù),所以可以保留歷史數(shù)據(jù)。歷史數(shù)據(jù)不會全部保留,超過一定時間的歷史數(shù)據(jù)會被徹底刪除,以減小空間占用以及避免歷史版本過多引入的性能開銷。
TiDB 使用周期性運(yùn)行的 GC(Garbage Collection,垃圾回收)來進(jìn)行清理,關(guān)于 GC 的詳細(xì)介紹參見 TiDB 垃圾回收 (GC)。
這里需要重點(diǎn)關(guān)注的是 tikv_gc_life_time 和 tikv_gc_safe_point 這條。tikv_gc_life_time
用于配置歷史版本保留時間,可以手動修改;tikv_gc_safe_point 記錄了當(dāng)前的 safePoint,用戶可以安全地使用大于 safePoint
的時間戳創(chuàng)建 snapshot 讀取歷史版本。safePoint 在每次 GC 開始運(yùn)行時自動更新。
1.初始化階段,創(chuàng)建一個表,并插入幾行數(shù)據(jù):
create table t (c int); insert into t values (1), (2), (3);
2.查看表中的數(shù)據(jù):
select * from t; +------+ | c | +------+ | 1 | | 2 | | 3 | +------+
3.查看當(dāng)前時間:
select now(); +---------------------+ | now() | +---------------------+ | 2020-02-02 16:45:26 | +---------------------+
4.更新某一行數(shù)據(jù):
update t set c=22 where c=2;
5.確認(rèn)數(shù)據(jù)已經(jīng)被更新:
select * from t; +------+ | c | +------+ | 1 | | 22 | | 3 | +------+
6.設(shè)置一個特殊的環(huán)境變量,這個是一個 session scope 的變量,其意義為讀取這個時間之前的最新的一個版本。
set @@tidb_snapshot="2020-02-02 16:45:26";
注意:這里的時間設(shè)置的是 update 語句之前的那個時間。在 tidb_snapshot 前須使用 @@ 而非 @,因?yàn)?@@ 表示系統(tǒng)變量,@ 表示用戶變量。
7.這里讀取到的內(nèi)容即為 update 之前的內(nèi)容,也就是歷史版本:
select * from t; +------+ | c | +------+ | 1 | | 2 | | 3 | +------+
8.清空這個變量后,即可讀取最新版本數(shù)據(jù):
set @@tidb_snapshot=""; select * from t; +------+ | c | +------+ | 1 | | 22 | | 3 | +------+
注意:在 tidb_snapshot 前須使用 @@ 而非 @,因?yàn)?@@ 表示系統(tǒng)變量,@ 表示用戶變量。
Python Web之表單:利用工廠函數(shù)定義表單集
2023-01-13Python學(xué)起來簡單嗎?零基礎(chǔ)可以學(xué)習(xí)嗎?
2023-01-12哪些語言可以用來開發(fā)網(wǎng)絡(luò)爬蟲程序?
2023-01-12表單字段的通用參數(shù)都有哪些?【PythonWeb知識】
2023-01-12Python程序員應(yīng)會的數(shù)據(jù)表基本操作:創(chuàng)建數(shù)據(jù)表
2023-01-112023年python培訓(xùn)班哪個靠譜?資源福利python學(xué)習(xí)教程全套下載
2023-01-09