热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQLServer开发技巧:修改表结构后的视图批量更新方法与实践

篇首语:本文由编程笔记#小编为大家整理,主要介绍了SQL Server修改表结构后批量更新所有视图相关的知识,希望对你有一定的参考价值。 最近修改了数据库表结构,数据同步的时候出了问题,发现很多数据明

篇首语:本文由编程笔记#小编为大家整理,主要介绍了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









推荐阅读
author-avatar
GXtingker
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有