时间:2021-05-24
项目最早是基于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对视图优化
我就废话不多说了,大家还是直接看代码吧~
//关系准备CREATE TABLE t01(a INT,b CHAR(32));CREATE VIEW v_t01 AS SELECT * FROM t01 WHERE a<10;//SQL准备SELECT * FROM v_t01 WHERE a<7;//测试:uu=# EXPLAIN SELECT * FROM v_t01 WHERE a<7; QUERY PLAN -------------------------------------------------------- Seq Scan on t01 (cost=0.00..17.35 rows=163 width=136) Filter: ((a < 10) AND (a < 7))(2 rows)从QUERY PLAN可以看出,现在是直接访问v_t01视图的基表t01,并且将视图的谓词条件与SQL语句的谓词条件组合,但是没有将谓词条件化简,很可惜,这点做的不是太好。
我曾在MySQL做过同样的测试,MySQL处理机制一样,并没有化简谓词条件。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
引文vue文档列表渲染中有条注意事项:这里提到的两种情况实际改变了数据但是没有触发视图更新。由此引出Vue.set(),先上文档API:this.$set()和
淘宝店铺特价活动说明要怎么写呢?有哪些注意事项?店铺活动是我们买家最为关注的焦点之一,那么淘宝店铺特价活动说明要怎么写呢?有哪些注意事项?今天小编就带各位卖
现在淘宝转播的方式已经普及到所有店铺,相信业者都知道利用淘宝转播开店流量不上升的情况。那么,淘宝直播中控台的注意事项是什么?淘宝直播中控台注意事项说明一、取得权
一介绍在笔者支持业务过程中,经常遇到开发咨询replaceinto的使用场景以及注意事项,这里做个总结。从功能原理,性能和注意事项上做个说明。二原理2.1当表中
双十二已经落幕,接下来商家要准备的就是2017淘宝年货节了,所以,今天我这里就来分享天天特价年货节的注意事项。2017淘宝天天特价年货节注意事项说明:一日常类目