電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>C語言|源代碼>在Postgres中進(jìn)行數(shù)據(jù)庫遷移時(shí)會(huì)遇到哪些問題

在Postgres中進(jìn)行數(shù)據(jù)庫遷移時(shí)會(huì)遇到哪些問題

2017-09-27 | rar | 0.2 MB | 次下載 | 2積分

資料介紹

  隨著數(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ì)把它們加到列表中。

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1電子電路原理第七版PDF電子教材免費(fèi)下載
  2. 0.00 MB  |  1490次下載  |  免費(fèi)
  3. 2單片機(jī)典型實(shí)例介紹
  4. 18.19 MB  |  92次下載  |  1 積分
  5. 3S7-200PLC編程實(shí)例詳細(xì)資料
  6. 1.17 MB  |  27次下載  |  1 積分
  7. 4筆記本電腦主板的元件識(shí)別和講解說明
  8. 4.28 MB  |  18次下載  |  4 積分
  9. 5開關(guān)電源原理及各功能電路詳解
  10. 0.38 MB  |  10次下載  |  免費(fèi)
  11. 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
  12. 0.11 MB  |  4次下載  |  免費(fèi)
  13. 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
  14. 0.63 MB  |  3次下載  |  免費(fèi)
  15. 89天練會(huì)電子電路識(shí)圖
  16. 5.91 MB  |  3次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234313次下載  |  免費(fèi)
  3. 2PADS 9.0 2009最新版 -下載
  4. 0.00 MB  |  66304次下載  |  免費(fèi)
  5. 3protel99下載protel99軟件下載(中文版)
  6. 0.00 MB  |  51209次下載  |  免費(fèi)
  7. 4LabView 8.0 專業(yè)版下載 (3CD完整版)
  8. 0.00 MB  |  51043次下載  |  免費(fèi)
  9. 5555集成電路應(yīng)用800例(新編版)
  10. 0.00 MB  |  33562次下載  |  免費(fèi)
  11. 6接口電路圖大全
  12. 未知  |  30320次下載  |  免費(fèi)
  13. 7Multisim 10下載Multisim 10 中文版
  14. 0.00 MB  |  28588次下載  |  免費(fèi)
  15. 8開關(guān)電源設(shè)計(jì)實(shí)例指南
  16. 未知  |  21539次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935053次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537791次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234313次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233045次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191183次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  14. 158M  |  183277次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138039次下載  |  免費(fèi)