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

          軟件下載吧

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

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

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

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

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

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

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

          相關下載

          查看所有評論+

          網友評論

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

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 国产精品一区在线麻豆| 成人免费视频一区二区| 国产精品亚洲高清一区二区| 精品一区二区三区在线视频| 成人免费一区二区无码视频| 精品无码AV一区二区三区不卡 | 精品一区二区AV天堂| 在线日韩麻豆一区| 精品无码一区二区三区爱欲九九| 日亚毛片免费乱码不卡一区| 国产麻豆精品一区二区三区| 亚洲bt加勒比一区二区| 国产在线一区二区三区| 91国在线啪精品一区| 国产福利电影一区二区三区,亚洲国模精品一区 | 日韩一区二区三区精品| 国产一区二区三区播放心情潘金莲| 精品一区二区三区东京热| 亚洲美女视频一区二区三区| 精品一区二区三区四区在线播放 | 天堂国产一区二区三区| 国模私拍一区二区三区| 国产综合一区二区| 麻豆天美国产一区在线播放| 日韩一区二区三区无码影院| 亚洲国产老鸭窝一区二区三区| 国产成人精品无码一区二区| 国产免费一区二区三区在线观看| 国产一区麻豆剧传媒果冻精品| 中文字幕在线视频一区| 久久高清一区二区三区| 国产日本一区二区三区| 国语对白一区二区三区| 精品一区二区三区无码视频| 一区二区在线视频观看| 亚洲AⅤ无码一区二区三区在线| 一区二区国产精品| 国产自产在线视频一区| 亚洲一区在线观看视频| 日本精品一区二区在线播放| 亚洲AⅤ视频一区二区三区|