更新表结构的同时更新相应的视图

 当修改一个表结构时(增加和删除列),引用到该表的视图并不会自动更新,这样就有可能导致一些问题。
比如:
有一个表T1有两列C1,C2.
视图VW1为:CREATE VIEW VW1 AS SELECT * FROM T1
如果增加列C3后,视图VW1执行的结果还是只有两列C1,C2

有几种方法来手动更新这个视图
1)重新执行视图脚本:CREATE VIEW VW1 AS SELECT * FROM T1
2)调用系统存储过程“ sp_refreshview”,来更新视图:EXEC sp_refreshview [VW1]
(试了 sp_recompile [VW1] 不起作用,不知它重新编译时干了什么)

这是知道该表被哪些视图引用的情况,如果不知道该表被哪些视图引用,可以用以下脚本:
SELECT DISTINCT 'EXEC sp_refreshview ''' + name + ''''
FROM sys.objects so INNER JOIN sys.sql_dependencies sd
ON so.object_id = sd.object_id
WHERE so.type = 'V'
AND sd.referenced_major_id = object_id('T1')

同理,也可找出引用它的存储过程来手动做一些修改:
SELECT DISTINCT name
FROM sys.objects so INNER JOIN sys.sql_dependencies sd
ON so.object_id = sd.object_id
WHERE so.type = 'P'
AND sd.referenced_major_id = object_id('T1')

或者干脆遍历更新一遍所有视图: http://www.ssw.com.au/SSW/KB/KB.aspx?KBID=Q1000592
DECLARE @ObjectName varchar (255)

DECLARE tnames_cursor CURSOR FOR SELECT name FROM sysobjects
    WHERE type = 'V' AND uid = 1 Order By Name
OPEN tnames_cursor
FETCH NEXT FROM tnames_cursor INTO @Objectname
WHILE (@@fetch_status <> -1)
BEGIN
    IF (@@fetch_status <> -2)
    BEGIN
        SELECT @ObjectName_header = 'Refreshing ' + @ObjectName
        PRINT @ObjectName_header
        EXEC('sp_refreshview ' + @ObjectName)
    END
    FETCH NEXT FROM tnames_cursor INTO @ObjectName
END


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值