日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

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

軟件下載吧

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

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

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

項目最早是基于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

相關下載

查看所有評論+

網友評論

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

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 中文字幕一区二区三区精彩视频 | 国产伦理久久精品久久久久 | 亚洲精品国产啊女成拍色拍 | 精品国产高清毛片 | 日韩高清在线不卡 | 精品韩国主播福利视频在线观看一 | 国产精品亚洲一区二区三区 | 久久久久久久亚洲精品一区 | 在线视频区 | 欧美激情久久久久久久大片 | 亚洲欧美日韩国产vr在线观 | 亚洲欧美日韩高清综合678 | 13一14周岁毛片免费 | 精品国产三级a∨在线观看 精品国产三级a在线观看 | 国产免费v片在线看 | 欧美三级不卡视频 | 一级a性色生活片久久毛片 一级a做爰片欧欧美毛片4 | 女人张开腿给男人捅 | 91亚洲欧美 | 久久99国产精品免费观看 | 国产精品亚洲综合网站 | 亚洲欧美另类在线视频 | 久久99精品视香蕉蕉 | 国产成人精品三级 | 九草视频 | 国产日韩久久久久69影院 | 欧美自拍在线 | 一个人免费观看日本www视频 | 中文字幕在线免费观看视频 | 免费人成在线观看网站品爱网 | 国产女人自拍 | 精品久久久久国产 | 亚洲欧美一区二区久久 | 亚洲午夜久久久久影院 | 99在线在线视频免费视频观看 | 日韩美女免费视频 | 加勒比一区二区 | 久久y| 曰本女同互慰高清在线观看 | 97视频免费公开成人福利 | 最刺激黄a大片免费观看 |