成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

簡(jiǎn)單數(shù)據(jù)庫(kù)遷移實(shí)踐

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù)
現(xiàn)在NoSQL流行,有一個(gè)原因也是因?yàn)椴恍枰タ桃馓幚韙able的schema,直接存儲(chǔ)數(shù)據(jù),這樣簡(jiǎn)單!所以也不會(huì)有數(shù)據(jù)庫(kù)表的遷移問(wèn)題。數(shù)據(jù)庫(kù)表遷移這一塊兒一直是一個(gè)麻煩點(diǎn),但我最近用了sqlite3做了個(gè)小項(xiàng)目,所以總結(jié)下數(shù)據(jù)庫(kù)遷移的方案。

[[194803]]

現(xiàn)在NoSQL流行,有一個(gè)原因也是因?yàn)椴恍枰タ桃馓幚韙able的schema,直接存儲(chǔ)數(shù)據(jù),這樣簡(jiǎn)單!所以也不會(huì)有數(shù)據(jù)庫(kù)表的遷移問(wèn)題。數(shù)據(jù)庫(kù)表遷移這一塊兒一直是一個(gè)麻煩點(diǎn),但我最近用了sqlite3做了個(gè)小項(xiàng)目,所以總結(jié)下數(shù)據(jù)庫(kù)遷移的方案。

原理

  1. 每一次數(shù)據(jù)表改動(dòng),都對(duì)應(yīng)一個(gè)數(shù)據(jù)庫(kù)版本號(hào)
  2. 數(shù)據(jù)遷移是漸進(jìn)式的,比如把數(shù)據(jù)庫(kù)版本從1 升級(jí)到n,那么就升級(jí)n-1次,版本1到2,2到3,直到n-1到n。

實(shí)施

1. 使用sqlite3的user_version 存貯自定義的數(shù)據(jù)庫(kù)版 

  1. /*設(shè)置版本號(hào)*/ 
  2.  
  3. PRAGMA user_version=1; 
  4.  
  5. /*讀取版本號(hào)*/ 
  6.  
  7. PRAGMA user_version;  

 2. 所有的數(shù)據(jù)庫(kù)升級(jí)文件,放在一個(gè)文件中,都直接使用sql文件,方便直接查看管理。文件結(jié)構(gòu)如下

 

 

 

文件結(jié)構(gòu)設(shè)計(jì)

  • v1.sql v2.sql, v3.sql等 是每個(gè)數(shù)據(jù)庫(kù)版本,完整的數(shù)據(jù)庫(kù)定義文件
  • v1tov2.sql, v2tov3.sql等 是間隔版本數(shù)據(jù)庫(kù)升級(jí)文件。一個(gè)數(shù)據(jù)m到n升級(jí)的過(guò)程就是,運(yùn)行 v[m]tov[m+1].sql, v[m+1]tov[m+2].sql, 直到 v[n-1]tov[n].sql
  • run.sh 就是每次要跑的數(shù)據(jù)遷移腳本,包括了當(dāng)前的版本號(hào)和遷移邏輯
  • 其中的v2.sql 到v[n].sql 不是必須的,只是為了方便查看當(dāng)前***的數(shù)據(jù)表設(shè)計(jì),如果存在v[n].sql 那么創(chuàng)建新數(shù)據(jù)庫(kù)也可以直接從這個(gè)文件來(lái)創(chuàng)建

3. 遷移腳本如下, 具體邏輯注釋中已經(jīng)寫(xiě)明

4. v[n].sql 和v[n-1]tov[n].sql 文件的***都去需要通過(guò)user_version來(lái)設(shè)置數(shù)據(jù)版本為n,一個(gè)v2tov3.sql 的demo如下:

總結(jié)

使用場(chǎng)景

目前這套方案適合數(shù)據(jù)量小,對(duì)停機(jī)維護(hù)可以接受的業(yè)務(wù)情況,因?yàn)樾枰C(jī)升級(jí),但是這個(gè)方案,足夠簡(jiǎn)單清晰且能滿(mǎn)足所有不同版本間的數(shù)據(jù)升級(jí)。

不足與展望

  1. 這個(gè)方案沒(méi)有考慮到數(shù)據(jù)升級(jí)失敗的回滾。由于是小業(yè)務(wù),所以考慮更多的是簡(jiǎn)單易維護(hù)。所以針對(duì)這種情況的,首先要保證升級(jí)腳本經(jīng)過(guò)了足夠的線上數(shù)據(jù)測(cè)試,經(jīng)的起考驗(yàn)。其次,一旦發(fā)生問(wèn)題,線上可以直接操作維護(hù),寫(xiě)腳本。這樣說(shuō),因?yàn)槟愣紱](méi)有測(cè)試到這種需要rollback的case,你也不能在寫(xiě)升級(jí)腳本的時(shí)候,知道這種case是怎樣,所以提前寫(xiě)好rollback的邏輯不一定可行或者合適。
  2. 部署時(shí),數(shù)據(jù)遷移之前要備份,數(shù)據(jù)量較大些,用增量備份,節(jié)省時(shí)間。備份有成熟的工具,而且備份方便升級(jí)失敗時(shí)rollback。部署的步驟應(yīng)該是: 拉代碼build(或者拉docker鏡像)-> 備份數(shù)據(jù)庫(kù) -> 升級(jí)數(shù)據(jù)庫(kù) -> 跑新的代碼
  3. 對(duì)于Android,iOS的設(shè)備中使用sqlite3的情況,數(shù)據(jù)遷移的邏輯是一樣。sql文件結(jié)構(gòu)設(shè)計(jì)可以重用,也可以寫(xiě)到代碼里去管理。遷移腳本需要轉(zhuǎn)換成native的Java或者Objective-C,Swift的代碼。
  4. 對(duì)于更大的業(yè)務(wù),多實(shí)例的的數(shù)據(jù)庫(kù)遷移可以使用Flyway 

 

責(zé)任編輯:龐桂玉 來(lái)源: 36大數(shù)據(jù)
相關(guān)推薦

2017-11-22 09:20:41

數(shù)據(jù)庫(kù)在線數(shù)據(jù)遷移Subscriptio

2020-06-08 10:41:13

云計(jì)算數(shù)據(jù)工具

2011-09-23 09:09:38

數(shù)據(jù)庫(kù)遷移

2020-08-13 07:42:15

數(shù)據(jù)庫(kù)Flyway代碼

2011-03-14 15:42:57

Oracle數(shù)據(jù)庫(kù)遷移復(fù)制

2009-03-19 09:44:07

SQL Server數(shù)據(jù)庫(kù)遷移數(shù)據(jù)庫(kù)

2011-04-29 14:30:23

2011-05-11 10:26:36

MySQL數(shù)據(jù)庫(kù)無(wú)縫遷移

2019-08-13 15:52:34

數(shù)據(jù)庫(kù)同步遷移

2021-04-09 08:21:25

數(shù)據(jù)庫(kù)索引數(shù)據(jù)

2011-06-29 14:01:30

多數(shù)據(jù)庫(kù)實(shí)例效率

2010-03-18 09:28:14

Oracle數(shù)據(jù)庫(kù)遷移

2009-03-23 09:05:01

2009-03-19 09:50:25

遷移微軟Analysis Se

2022-02-10 10:51:35

數(shù)據(jù)庫(kù)

2024-05-28 00:00:30

Golang數(shù)據(jù)庫(kù)

2013-10-08 09:54:41

數(shù)據(jù)庫(kù)安全數(shù)據(jù)庫(kù)管理

2009-11-20 15:03:29

2009-07-01 11:08:14

JSP DestoryJSP Init數(shù)據(jù)庫(kù)鏈接

2009-09-09 13:07:37

創(chuàng)建Linq數(shù)據(jù)庫(kù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产成人在线一区二区 | 日日骚av | 欧美理论片在线 | 在线观看免费黄色片 | 国产乱码精品1区2区3区 | 国产精品一区二区在线播放 | 国产成人综合一区二区三区 | 国产露脸国语对白在线 | 亚洲国产一区二区三区在线观看 | 久久精品国产免费一区二区三区 | 九九精品网| 在线观看成人av | 黑人巨大精品欧美一区二区免费 | 国产精品久久久久久吹潮 | 人人干人人草 | 免费成人高清 | 狠狠干五月天 | 久久精品国产一区二区三区 | 成人午夜视频在线观看 | 欧美一区二区三区在线观看 | 亚洲人成在线观看 | 日韩av免费看 | 亚洲一区二区三区观看 | 精品国产一区二区在线 | 成人精品国产 | 一级片av | 亚洲成人在线免费 | 中文字幕一二三区 | 久久精品免费观看 | 国产目拍亚洲精品99久久精品 | 欧美video | 精品欧美一区二区三区久久久 | 精品免费国产一区二区三区四区介绍 | 精品成人av| 欧美亚洲另类在线 | 亚洲91精品| 欧美一区二区在线观看 | 一区二区三区久久久 | 免费毛片网 | 久草电影网 | 日本在线视频中文字幕 |