OracleSQL 对原本的table更新,如何让VIEW也随之更新?

OracleSQL 对原本的table更新,如何让VIEW也随之更新?,第1张

会,视图view是根据table建立的,当更新table是,如果涉及视图所在字段,那么视图也会随之更新。

当然如果你说的修改是修改字段名称或者字段长度一类的,改变基表的一些性质的 *** 作,那么视图会失效,需要重新编译一下视图才可以。

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

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

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

删除其中一表数据后,视图不自动更新。

oracle全称Oracle Database,是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库解决方案。


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

原文地址: https://outofmemory.cn/sjk/9984858.html

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

发表评论

登录后才能评论

评论列表(0条)

保存