PostgreSQL 修改视图的操作
最近发现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的坑吧。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
推荐阅读
-
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等
-
Vue.js中对css的操作(修改)具体方式详解
-
Laravel 手动开关 Eloquent 修改器的操作方法
-
PHP连接及操作PostgreSQL数据库的方法详解
-
CentOS7.x卸载与安装MySQL5.7的操作过程及编码格式的修改方法
-
MSSQL监控数据库的DDL操作(创建,修改,删除存储过程,创建,修改,删除表等)
-
mysql视图之确保视图的一致性(with check option)操作详解
-
我来告诉你:VS2019开发ASP.NET Core 3.0 Web项目,修改视图后,刷新浏览器看不到修改后的效果怎么处理
-
xadmin进行全局配置(修改模块名为中文以及其他自定义的操作步骤)
-
关于python的列表操作(一):取值,增加,修改,删除