Oracle数据库,怎样更新联接视图

Oracle数据库,怎样更新联接视图,第1张

应满足条件:

源表尽量使单表,否则限制会比较多。

下面的情况不应出现,否则不允许更新:

1.distinct 关键字

2.集合运算或分组函数。eg:intersect、sum、max、count ....

3.出现group by 、order by、model、start with .....

4.出现伪列关键字:eg:rownum.

3.还应考虑基表的一些约束,这些约束对视图数据的更新都有一定影响,如果需要创建可以更新的视图,可以使用instead of 触发器。

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

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

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

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

老弟我要挖苦你一下:

SQL 2005 以后 可以使用

多句表格值函数,

这个支持控制语句,插入更新等块 *** 作,可以弥补视图的不足。很多人都认为可以用函数取缔

视图。

在sqlserver 社区,经常有人吵架,是要存储过程,函数,还是视图?

其次我不支持你在数据库上屏蔽差异,这个多少是奇淫技巧,如果是南天数据库,你不是要玩吐血。

就用最基本的sql92标准实现功能,屏蔽数据库差异是最好的选择。

但是你只是获得一个自增编号,写函数都浪费。

举个例子:

Declare @tb table (PName nvarchar(30) ,Code_No nvarchar(30))

insert into @tb values('P01','A')

insert into @tb values('P02','B')

insert into @tb values('P03','C')

insert into @tb values('P04','D')

insert into @tb values('P05','E')

insert into @tb values('P06','F')

SELECT

ROW_NUMBER() OVER (ORDER BY PName) as Rank,Code_No,PName

FROM @tb

--------------

返回结果:

1 AP01

2 BP02

3 CP03

4 DP04

5 EP05

6 FP06

----

这可行否?

如果是 2000 使用子查询也可轻松实现自增编号啊。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存