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

          軟件下載吧

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

          PostgreSQL 數(shù)據(jù)庫基礎(chǔ) 更新視圖腳本的注意事項(xiàng)

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

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

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

          PostgreSQL 數(shù)據(jù)庫基礎(chǔ) 更新視圖腳本的注意事項(xiàng)

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

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

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

          DROP VIEW IF EXISTS B CASCADE;
          CREATE VIEW B AS
          …;
          DROP VIEW IF EXISTS A CASCADE;
          CREATE VIEW A AS
          …;

          標(biāo)簽MySQL,技術(shù)文檔,數(shù)據(jù)庫,PostgreSQL

          相關(guān)下載

          查看所有評(píng)論+

          網(wǎng)友評(píng)論

          網(wǎng)友
          您的評(píng)論需要經(jīng)過審核才能顯示

          熱門閱覽

          最新排行

          公眾號(hào)

          主站蜘蛛池模板: 日本一区二区三区在线视频观看免费| 国产在线一区二区| 精品人妻一区二区三区浪潮在线| 国产精品亚洲午夜一区二区三区| 亚洲视频在线一区| 亚洲一区二区三区在线观看蜜桃| 无码国产精品一区二区免费虚拟VR| 精品一区二区三区影院在线午夜| 三上悠亚国产精品一区| 无码人妻一区二区三区免费看| 亚洲乱码av中文一区二区| 国内精自品线一区91| 国产一区在线播放| 精品日产一区二区三区手机| 少妇精品久久久一区二区三区| 日本v片免费一区二区三区 | 亚洲综合国产一区二区三区| 伊人久久精品无码av一区| 国产成人精品日本亚洲专一区 | 国产a久久精品一区二区三区| 国产成人无码精品一区在线观看| 国产精品熟女一区二区| 日韩免费视频一区| 无码AV中文一区二区三区| 日本中文一区二区三区亚洲| 极品少妇一区二区三区四区| 亚洲国产精品一区第二页| 国产福利电影一区二区三区久久久久成人精品综合 | 中文字幕VA一区二区三区 | 国产麻豆精品一区二区三区| 久久青草精品一区二区三区| 精品一区二区三区在线观看视频| 日本免费一区二区三区最新| 无码人妻精品一区二区三区9厂 | 亚洲AV无码一区二区三区网址| 一区二区在线视频观看| 免费看无码自慰一区二区| 亚洲乱码一区二区三区国产精品| 97精品国产福利一区二区三区| 国产免费一区二区三区VR| 精品欧洲av无码一区二区 |