数据库里面的视图会不会自动更新?

数据库里面的视图会不会自动更新?,第1张

当然会了,视图数据库表数据的表现形式,类似于sql查询,视图的数据都来自基础表,所以是一个级联的关系。

基本数据库表类似超市的仓库,存储了符合该表的所有数据;

视图则类似超市的货架,该货架描述了需陈列的商品。

所以数据库的更新、插入与删除 *** 作的是基础数据库表,只影响了视图罗列出来的数据。

plsql表更新后视图未更新,可能是不汇总或数据被加工过

一般来说,通过视图进行数据更新(INSERT、UPDATE、DELETE),只要该视图是单纯的SELECT语句定义的视图即可。也就是说,如果是不汇总或数据被加工过而是直接显示数据的视图,一般可以通过该视图来更新数据。在这种情况下,在数据库侧,将针对视图的DML语句(INSERT、UPDATE、DELETE)自动转换成表的DML语句,来更新数据。

但是,对于定义的复杂视图,DML语句无法在数据库侧转换成表的DML语句,因此会发生错误。这种情况下如果在数据库侧无法转换成表的DML语句,我们也可以通过开发者准备的程序,转换成表的DML语句,也可以实现对视图的DML。那就是“INSTEAD OF 触发器”

只有特定的视图才能被更新,而且更新视图有一些限制条件

但是通过视图去更新则必须注意以下条件:

1、如果视图有一个基本关系的简单查询生成,而且它还包含了基本关系中的主关键字或是候选关键字,则可以通过这个视图进行更新 *** 作。

2、不允许对涉及到多个基本关系的视图进行更新。

3、如果视图的生成中涉及到聚集或是分组 *** 作,则不允许通过这个视图进行更新。

ISO标准给出的视图的可更新充要条件为:

1、没有指定DISTINCT,即重复元组未从查询结果中消除;

2、定义查询的SELECT列表中的每个元素均为列名(而不是常量,表达式或聚合函数),且列名出现不能多于一次;

3、FROM子句只能指定一个表,即视图必须有一个源表且用户有请求该表的权限。如果源表本身就是一个视图,那么视图必须满足这些条件。因此,排除了基于连接、并(UNION)、交(INTERSECT)或差(EXCEPT) *** 作的所有视图;

4、where子句不能包含任何引用了FROM子句的表的嵌套SELECT *** 作。

5、定义查询不能有GROUP BY或HAVING子句。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9618901.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存