承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

PostgreSQL 数据库基础 怎么修改视图的操作

管理员 2023-08-14 08:43:41 互联网圈 0 ℃ 0 评论 2475字 收藏

最近发现PostgreSQL(create or replace) 修改视图有很多的限制,不像SQL Server和Oracle那样可以随便修改。

毛病提示

修改视图原有字段

ERROR: cannot change name of view column “user_id” to “?column?”

删除视图原有字段

ERROR: cannot drop columns from view

找到以下缘由,内容原文

究其缘由,是PostgreSQL虽然支持CREATE OR REPLACE VIEW语义,却有着容易让人疏忽的重要限制(Oracle没有该限制),其官方文档这样描写:

即:更新视图只能在最后增加字段,不能改字段名、不能删除字段、也不能在中间增加字段,这在项目开发阶段是不可忍耐的。虽然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
…;

补充:postgresql创建视图

今天使用postgresql创建视图时,使用的名字全是大写的 比如V_TEST

创建好了,是没有问题的,显示创建的视图名字也是V_TEST。

然后我就开始查询, select * from V_TEST 直接就报错了,说v_test视图不存在。

我就疑惑了,为何创建时,你不给我转成小写,查询时,转成了小写。

不管怎样,到时再说吧,多是有个配置或其它之类的致使转为小写了,但是目前没有时间研究了,后续有空再研究吧,也算是一个postgresql的坑吧。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有毛病或未斟酌完全的地方,望不吝赐教。

文章来源:丸子建站

文章标题:PostgreSQL 数据库基础 怎么修改视图的操作

https://www.wanzijz.com/view/71390.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信