PostgreSQL更新视图脚本的注意事项

Posted 闻歌感旧

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PostgreSQL更新视图脚本的注意事项相关的知识,希望对你有一定的参考价值。

项目最早是基于Oracle的,移植到PostgreSQL后,本着尽量少修改的原则,创建/更新视图的脚本也沿用了Oracle风格的CREATE OR REPLACE VIEW形式。但是每当要更新视图定义时,常常报"cannot change name of view column xxx to yyy"的错误,通常是在视图修改某字段名、中间增加字段、删除字段时发生。

究其原因,是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更新视图脚本的注意事项的主要内容,如果未能解决你的问题,请参考以下文章

小程序各种功能代码片段整理---持续更新

活动到片段通信:当我尝试从活动更新片段中的文本视图时,出现空指针异常

从活动更新视图页面中片段中的列表视图

从另一个片段中的目录更新片段中的列表视图元素

ViewPager 使用片段更新屏幕外视图而不是主视图

无法从 ViewPager 中的另一个片段刷新/更新片段中的列表视图