1. 程式人生 > >PostgreSQL更新視圖腳本的註意事項

PostgreSQL更新視圖腳本的註意事項

移植 postgre cas 更新 分享 關系 不可 post 刪除

項目最早是基於Oracle的,移植到PostgreSQL後,本著盡量少修改的原則,創建/更新視圖的腳本也沿用了Oracle風格的CREATE OR REPLACE VIEW形式。但是每當要更新視圖定義時,常常報"cannot change name of view column xxx to yyy"的錯誤,通常是在視圖修改某字段名、中間增加字段、刪除字段時發生。

究其原因,是PostgreSQL雖然支持CREATE OR REPLACE VIEW語義,卻有著容易讓人忽略的重要限制(Oracle沒有該限制),其官方文檔這樣描述:

技術分享圖片

即:更新視圖只能在最後增加字段,不能改字段名、不能刪除字段、也不能在中間增加字段,這在項目開發階段是不可忍受的。雖然PostgreSQL提供了ALTER VIEW的語句,但怎麽也不如直接放在CREATE VIEW裏那樣直觀。

因此,建議腳本放棄Oracle風格的CREATE OR REPLACE VIEW形式,而改用MySQL風格的先DROP VIEW再CREATE VIEW的形式。不過,如果VIEW間存在層次引用關系,如視圖A建立在視圖B之上,則CREATE時必須先建B後建A,DROP時必須先刪A再刪B。當層次引用較多或變化較頻繁時,調整順序又是件麻煩事。

為降低復雜性,腳本最終只考慮CREATE VIEW時的順序,而在DROP VIEW時,綜合使用IF EXISTS 和CASCADE選項,如下所示:

DROP VIEW IF EXISTS B CASCADE;

CREATE VIEW B AS
...;

DROP VIEW IF EXISTS A CASCADE; CREATE VIEW A AS ...;

PostgreSQL更新視圖腳本的註意事項