当前位置:Gxlcms > 数据库问题 > SQL Server修改表结构后批量更新所有视图

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

时间:2021-07-01 10:21:17 帮助过:8人阅读

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

 

原文链接: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修改表结构后批量更新所有视图

标签:ring   使用   har   cell   存储   traints   批量   ref   ace   

人气教程排行