时间:2021-05-24
最近发现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的坑吧。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
项目最早是基于Oracle的,移植到PostgreSQL后,本着尽量少修改的原则,创建/更新视图的脚本也沿用了Oracle风格的CREATEORREPLACEV
PostgreSql数据库对象主要有数据库、表、视图、索引、schema、函数、触发器等。PostgreSql提供了information_schemasche
修改postgresql存储目录:sudorsync-av/var/opt/gitlab/postgresql/data/gitlab/修改/etc/gitla
本文实例讲述了mysql视图原理与用法。分享给大家供大家参考,具体如下:本文内容:什么是视图创建视图查看视图视图的修改视图的删除视图的数据操作首发日期:2018
Postgresql数据库支持灵活的权限管理,可以控制一个角色(组、用户)对某张表的读、写、更新、删除等操作权限、执行某个函数的权限以及操作(使用、更新等)视图