資料介紹
隨著數(shù)據(jù)庫的增長與擴(kuò)展,你需要對(duì)一些操作給予更多的關(guān)注。你可能沒有完全意識(shí)到,在開發(fā)環(huán)境中執(zhí)行應(yīng)用程序時(shí),執(zhí)行某些操作的成本,與在生產(chǎn)環(huán)境中大相徑庭。在某一時(shí)刻,我們中的大多數(shù)人都犯了錯(cuò),在5分鐘時(shí)開始運(yùn)行一些遷移,過15分鐘仍然在運(yùn)行,突然間生產(chǎn)流量受到了影響。
有兩種操作發(fā)生的很頻繁,每種操作都有一些簡單的方法可以減少停機(jī)時(shí)間。讓我們看看每一個(gè)操作,它們是如何工作的,以及如何以更安全的方式來處理它們。
添加新列
在Postgres中添加一個(gè)新列實(shí)際上代價(jià)是很低的。當(dāng)你這樣做的時(shí)候,它會(huì)更新對(duì)于已有列時(shí)刻的跟蹤,它幾乎是瞬時(shí)的。當(dāng)對(duì)某個(gè)列有一些約束時(shí),這一部分就會(huì)變得很昂貴。一個(gè)約束可以是一個(gè)主鍵或者外鍵,或者是一些唯一性約束。 Postgres不得不掃描表中的所有記錄以確保沒有違反這些約束。添加諸如“非空”等一些約束時(shí),可能會(huì)有一些違反,但這不是最常見的原因。
造成添加新列遲緩最常見的原因是大部分的框架中為新列設(shè)置缺省值太過簡單。對(duì)于所有的新記錄這是一回事,但是對(duì)于已有的表來說,這意味著數(shù)據(jù)庫不得不要讀取所有的記錄并且向這些記錄中重寫新的缺省值。對(duì)于只有幾百條記錄的表來說,這還不算太糟,但是對(duì)于上千萬條記錄的表來說,這時(shí)間就無法容忍了 。
簡而言之,在添加新列時(shí),如果將其設(shè)為非空或者在創(chuàng)建是設(shè)置一個(gè)缺省值都會(huì)給你帶來麻煩。解決之道是不要這樣做。但是,如果你需要一個(gè)缺省值或者不想字段為空時(shí)該怎么辦。這有一些你可以采取的簡單步驟,將你的遷移工作從一步分為 四步:
1. 添加新列,允許其為空
2. 開始在所有新記錄和更新中寫入默認(rèn)值
3. 逐步回填缺省值
4. 應(yīng)用你的約束
是的,只是稍微多一點(diǎn)工作,對(duì)現(xiàn)有工作的影響很微小。
類似大部分的DDL操作,創(chuàng)建索引時(shí)會(huì)加鎖,這就意味著所有新的數(shù)據(jù)必須等待索引創(chuàng)建完成后才可以寫入。對(duì)于新建的或者小規(guī)模的表,等待的時(shí)間不是很明顯,但是對(duì)于大規(guī)模數(shù)據(jù)庫,等待的時(shí)間可能是以分鐘甚至小時(shí)計(jì)添加索引的本意是為了提高查詢速度,但是實(shí)際的效果卻是降低了速度,這真是有點(diǎn)諷刺。
Postgres中對(duì)于這個(gè)問題的答案是 CONCURRENT 創(chuàng)建索引。就是在后臺(tái)逐步創(chuàng)建索引。你可以通過:CREATE INDEX CONCURRENTLY語句并發(fā)創(chuàng)建索引。一旦創(chuàng)建了索引,只要你做想做的事情,Postgres就會(huì)在查詢中使用它。
可以提供幫助的工具
這是一個(gè)不錯(cuò)的實(shí)踐活動(dòng),了解運(yùn)行遷移時(shí)會(huì)發(fā)生什么,以及對(duì)于性能的影響。即便如此,你也不必只憑自己的力量去管理這些。至少對(duì)于Rails還有工具能幫組你掌握它。Strong migrations能夠幫組你掌握很多這些昂貴的操作,如果你在使用Rails,你可以考慮看一看。
還要其他的工具和秘訣可以有助于Postgres中的數(shù)據(jù)遷移?給我留言,我會(huì)把它們加到列表中。
- 面向NoSQL數(shù)據(jù)庫的JSON文檔異常檢測模型 20次下載
- 創(chuàng)建新的數(shù)據(jù)庫和更改SQL Server CE數(shù)據(jù)庫中的數(shù)據(jù)操作教程免費(fèi)下載 5次下載
- 如何使用Labwindow CVI軟件平臺(tái)進(jìn)行Mysql數(shù)據(jù)庫開發(fā) 22次下載
- 兩張表之間進(jìn)行數(shù)據(jù)庫查詢時(shí)聚合函數(shù)用法的詳細(xì)實(shí)例說明
- 數(shù)據(jù)庫教程之如何進(jìn)行數(shù)據(jù)更新和視圖的詳細(xì)資料說明 2次下載
- 數(shù)據(jù)庫教程之如何進(jìn)行數(shù)據(jù)查詢的詳細(xì)資料說明 8次下載
- 數(shù)據(jù)庫教程之如何進(jìn)行數(shù)據(jù)庫保護(hù) 12次下載
- 數(shù)據(jù)庫系統(tǒng)概論之如何進(jìn)行數(shù)據(jù)庫編程的資料概述 13次下載
- 數(shù)據(jù)庫學(xué)習(xí)入門資料之如何進(jìn)行數(shù)據(jù)庫設(shè)計(jì) 14次下載
- 數(shù)據(jù)庫教程之如何進(jìn)行數(shù)據(jù)庫設(shè)計(jì) 21次下載
- 如何進(jìn)行數(shù)據(jù)庫設(shè)計(jì)?數(shù)據(jù)庫設(shè)計(jì)介紹和需求分析及結(jié)構(gòu)設(shè)計(jì)資料概述 0次下載
- 數(shù)據(jù)庫學(xué)習(xí)入門之如何進(jìn)行數(shù)據(jù)庫設(shè)計(jì)詳細(xì)分析概述資料免費(fèi)下載 14次下載
- 海量數(shù)據(jù)庫遷移與升級(jí)_樓宏良 0次下載
- 基于MPI的并行數(shù)據(jù)庫的研究與實(shí)現(xiàn)
- 組態(tài)王環(huán)境下數(shù)據(jù)庫訪問技術(shù)及其應(yīng)用
- 如何使用原生ClickHouse函數(shù)和表引擎在兩個(gè)數(shù)據(jù)庫之間遷移數(shù)據(jù) 611次閱讀
- OpenHarmony關(guān)系型數(shù)據(jù)庫概述 880次閱讀
- 什么是數(shù)據(jù)庫 1190次閱讀
- Python-mysql數(shù)據(jù)庫基礎(chǔ) 614次閱讀
- 常見的數(shù)據(jù)庫管理 1916次閱讀
- 用docker啟動(dòng) postgres 數(shù)據(jù)庫 2467次閱讀
- 云數(shù)據(jù)庫和自建數(shù)據(jù)庫的區(qū)別及應(yīng)用 4412次閱讀
- 分析探討微服務(wù)遷移如何影響數(shù)據(jù)庫管理和分解數(shù)據(jù)庫的步驟 2051次閱讀
- 一文看懂數(shù)據(jù)庫原理與應(yīng)用 11.7w次閱讀
- 數(shù)據(jù)庫引擎是什么 1.1w次閱讀
- 冷備份的優(yōu)缺點(diǎn)_數(shù)據(jù)庫冷備份教程詳解 3049次閱讀
- 什么是數(shù)據(jù)庫技術(shù)_數(shù)據(jù)庫技術(shù)的基礎(chǔ)知識(shí) 1.3w次閱讀
- 淺談數(shù)據(jù)庫技術(shù)的應(yīng)用與發(fā)展 1.1w次閱讀
- 目前流行的數(shù)據(jù)庫_構(gòu)建數(shù)據(jù)庫系統(tǒng)的流程 7076次閱讀
- cassandra數(shù)據(jù)庫遷移與擴(kuò)容 5558次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1490次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說明
- 4.28 MB | 18次下載 | 4 積分
- 5開關(guān)電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
- 0.63 MB | 3次下載 | 免費(fèi)
- 89天練會(huì)電子電路識(shí)圖
- 5.91 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論
查看更多