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

軟件下載吧

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

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

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

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

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

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

即:更新視圖只能在最后增加字段,不能改字段名、不能刪除字段、也不能在中間增加字段,這在項目開發(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時必須先建B后建A,DROP時必須先刪A再刪B。當層次引用較多或變化較頻繁時,調(diào)整順序又是件麻煩事。

為降低復(fù)雜性,腳本最終只考慮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,技術(shù)文檔,數(shù)據(jù)庫,PostgreSQL

相關(guān)下載

查看所有評論+

網(wǎng)友評論

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

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 中文字幕日韩精品无码内射| 免费一级毛片在线播放泰国| 久久久久波多野结衣高潮| 色综合久久天天影视网| 成人观看网站a| 人妻无码久久中文字幕专区| 91久久精品午夜一区二区| 欧美亚洲综合另类在线观看| 国产又黄又硬又湿又黄的| 中文字幕无码日韩欧毛| 男人j桶进女人免费视频 | 国产91精品在线| ts人妖另类在线| 欧美性视频在线播放黑人| 国产成人女人毛片视频在线| 中文字幕日韩高清| 激情无码人妻又粗又大| 国产精品28p| 亚洲中文字幕av每天更新| 国产午夜视频在线观看| 日韩精品欧美高清区| 番茄视频在线观看免费完整| 黑人大长吊大战中国人妻| groupsex娇小紧的5一8| 久久人人爽爽人人爽人人片AV| 亚洲白色白色在线播放| 国产91在线|日韩| 国产男女猛视频在线观看网站| 女神们的丝袜脚战争h| 日韩一区二区三区电影在线观看| 激情综合网婷婷| 91啦视频在线| 精品无码一区二区三区在线 | 久久精品国产99精品国产2021| 美女张开腿黄网站免费| 国产高清自产拍av在线| 久久婷婷五月综合97色直播| 男女搞基视频软件| 国产成人综合洲欧美在线| а√在线地址最新版| 最近中文字幕免费完整国语|