SQL Server修改表结构后批量更新所有视图

Posted Waine.Lau

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server修改表结构后批量更新所有视图相关的知识,希望对你有一定的参考价值。

最近修改了数据库表结构,数据同步的时候出了问题,发现很多数据明明已经修改,但是通过视图筛选出来的还是原来的数据,所以怀疑应该是视图缓存了数据,在园子里找到下面的博文,在这里做个记录备忘。

 

原文链接:http://www.cnblogs.com/yashen/archive/2004/12/23/81000.html

 

我们在使用SqlServer时经常遇到这种情况,当修改某个表的结构后,相关的视图就不对了而导致程序错误,因此就有个下面这个存储过程。

CREATE PROCEDURE RefreshAllView AS
DECLARE MyCursor CURSOR
FOR select Name from dbo.sysobjects where OBJECTPROPERTY(id, N\'IsView\') = 1 and (not name in (\'sysconstraints\',\'syssegments\'))
 
  
DECLARE @name varchar(40)
OPEN MyCursor
 
FETCH NEXT FROM MyCursor INTO @name
WHILE (@@fetch_status <> -1)
BEGIN
 IF (@@fetch_status <> -2)
 begin
 exec sp_refreshview @name
 end
 FETCH NEXT FROM MyCursor INTO @name
END
 
CLOSE MyCursor
DEALLOCATE MyCursor

以上是关于SQL Server修改表结构后批量更新所有视图的主要内容,如果未能解决你的问题,请参考以下文章

sql 批量修改,,mysql数据库某表内特定字符后40位后面添加添加特定内容怎样实现。

sql server如何批量更新数据。

sqlserver中如何批量修改一个表的数据

在 SQL Server 2005 中从小表批量复制到大表

设置Sql server用户对表视图存储过程架构的增删改查权限

SQL Server 视图插入更新