欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么簡(jiǎn)單分析數(shù)據(jù)庫(kù)遷移

這篇文章給大家介紹怎么簡(jiǎn)單分析數(shù)據(jù)庫(kù)遷移,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比九江網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式九江網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋九江地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。

現(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ù)版

/*設(shè)置版本號(hào)*/  PRAGMA user_version=1;  /*讀取版本號(hào)*/  PRAGMA user_version;

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

怎么簡(jiǎn)單分析數(shù)據(jù)庫(kù)遷移

文件結(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)單清晰且能滿足所有不同版本間的數(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 

關(guān)于怎么簡(jiǎn)單分析數(shù)據(jù)庫(kù)遷移就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

本文名稱:怎么簡(jiǎn)單分析數(shù)據(jù)庫(kù)遷移
瀏覽地址:http://aaarwkj.com/article20/ipddjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、做網(wǎng)站、App設(shè)計(jì)網(wǎng)站設(shè)計(jì)公司、用戶體驗(yàn)、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)
欧美精品青青久久久久久| 相泽南亚洲一区二区在线播放| 亚洲精品中文字幕久久| 日本sm视频在线观看| 97视频高清在线观看| 日韩亚洲欧美另类精品| 亚洲精品中文字幕乱码三区91 | 成人污视频网站在线观看| 久青青国产综合自拍视频在线观看| 日韩亚洲欧美精品另类| 精品在欧美一区二区少妇| 久久精品中文字幕有码日本道| 亚洲中文乱码一区二区| 免费在线观看日韩av大片| 亚洲黄色片成年人免费观看| 美女性生活免费视频网站| 亚洲成人影院中文字幕| 韩国电视剧大全免费国语观看 | 日本不卡不二三区在线看| 一区二区三区日本在线观看| 97精品在线免费视频| 欧美激情中文字幕日韩精品| 中文字幕人妻日韩在线| 欧美日韩av在线一区二区| 国产乡下三级_三级全黄| 在线亚洲av不卡一区二区三区| 国产视频一区二区麻豆| 四虎久久久最新网址| 免费看欧美黄片在线看| 精品国产一区二区三区av在线| 亚洲天堂av在线观看| 欧美熟妇在线视频你懂的| 国产av白浆一区二区色爽黄| 日韩成人在线视频观看| 日本精品三级一区二区视频| 九月丁香花开综合网| 亚洲最大av免费在线看| 日韩大片一区二区三区在线观看| 国产精品一区二区av麻豆| 美女呻吟被爽到高潮在线| 91香蕉国产精品日韩|