下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 技術開發 > 數據庫 > PostgreSQL 數據庫基礎 更新視圖腳本的注意事項

PostgreSQL 數據庫基礎 更新視圖腳本的注意事項

時間:2024-02-05 11:03作者:下載吧人氣:28

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

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

PostgreSQL 數據庫基礎 更新視圖腳本的注意事項

即:更新視圖只能在最后增加字段,不能改字段名、不能刪除字段、也不能在中間增加字段,這在項目開發階段是不可忍受的。雖然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
…;

標簽MySQL,技術文檔,數據庫,PostgreSQL

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 大臿蕉香蕉大视频成人| 特区爱奴在线观看| 日本精品久久久久中文字幕| 国产白嫩美女在线观看| 亚洲午夜久久久影院伊人| 91精品欧美综合在线观看| 深夜福利一区二区| 在线观看亚洲视频| 亚洲欧美日韩综合精品网| 97精品伊人久久久大香线蕉| 波多野结衣和邻居老人| 国内精品视频在线观看| 亚洲欧洲久久久精品| 呦交小u女国产秘密入口| 欧美巨大xxxx做受中文字幕| 国产精品亚洲成在人线| 亚洲另类欧美综合久久图片区| 老妇bbwbbw视频| 欧洲mv日韩mv国产| 国产夜趣福利免费视频| 久久久久人妻精品一区蜜桃| 色综合天天娱乐综合网| 成人国产精品免费视频| 六度国产福利午夜视频黄瓜视频| 一区二区三区电影在线观看| 男人天堂视频网| 大象传媒在线观看| 亚洲成a人片在线观看久| 日本人的色道免费网站| 日韩在线永久免费播放| 国产chinese男同志movie外卖| 中国老太大bbw| 狠狠色丁香九九婷婷综合五月| 国产香港日本三级在线观看 | 黄色永久免费网站| 无码囯产精品一区二区免费| 初女破苞国语在线观看免费| 99精品国产在热久久无毒不卡| 欧美日韩精品久久久免费观看 | 98久久人妻无码精品系列蜜桃| 欧美日韩亚洲成色二本道三区|