SqlServer更新视图存储过程函数脚本

--视图、存储过程、函数名称

DECLARE @NAME NVARCHAR(255);

--局部游标

DECLARE @CUR CURSOR

--自动修改未上状态为旷课

SET @CUR=CURSOR SCROLL DYNAMIC FOR

SELECT NAME FROM DBO.SYSOBJECTS

    WHERE NAME NOT IN (‘SYSCONSTRAINTS‘,‘SYSSEGMENTS‘)

        AND

        (

            OBJECTPROPERTY(ID, N‘IsView‘) = 1               --视图

            OR OBJECTPROPERTY(ID,N‘IsProcedure‘) = 1        --存储过程

            OR OBJECTPROPERTY(ID,N‘IsScalarFunction‘) = 1   --标量函数

            OR OBJECTPROPERTY(ID,N‘IsTableFunction‘) = 1    --标题函数

            OR OBJECTPROPERTY(ID,N‘IsInlineFunction‘) = 1   --内联函数

        );

OPEN @CUR;

FETCH NEXT FROM @CUR INTO @NAME

WHILE (@@FETCH_STATUS=0)

BEGIN

    DECLARE @OldText NVARCHAR(MAX);

    DECLARE @NewText NVARCHAR(MAX);

    --读取创建脚本,当脚本超长时分成多条记录时合并

    SELECT @[email protected] + CHAR(10) + CHAR(13) + RTRIM(TEXT) FROM SYSCOMMENTS WHERE ID = OBJECT_ID(@NAME);

    --将创建脚本替换为更新脚本

    SET @NewText=REPLACE(@OldText,N‘CREATE VIEW‘,N‘ALTER VIEW‘);

    SET @NewText=REPLACE(@NewText,N‘CREATE PROCEDURE‘,N‘ALTER PROCEDURE‘);

    SET @NewText=REPLACE(@NewText,N‘CREATE FUNCTION‘,N‘ALTER FUNCTION‘);

    

    BEGIN TRY

        EXEC(@NewText);

    END TRY

    BEGIN CATCH

        PRINT N‘---------------------------------------------------------------------------‘;

        PRINT @NAME + N‘ : ‘ + ERROR_MESSAGE();

        --PRINT @OldText;

        PRINT N‘---------------------------------------------------------------------------‘;

    END CATCH

    FETCH NEXT FROM @CUR INTO @NAME

END

CLOSE @CUR;

DEALLOCATE @CUR;

时间: 2024-10-03 03:47:54

SqlServer更新视图存储过程函数脚本的相关文章

onAttachedToWindow () 和 onDetachedFromWindow () ; 以及更新视图的函数ondraw() 和dispatchdraw()的区别

protected void onAttachedToWindow() This is called when the view is attached to a window. At this point it has a Surface and will    start drawing. Note that this function is guaranteed to be called  before onDraw(android.graphics.Canvas), however it

sqlserver中的存储过程 函数 事物 索引及视图

                                       存储过程和函数具体的区别: 核心提示:本质上没区别.只是函数有限制只能返回一个标量,而存储过程可以返回多个.并且函数是可以嵌入在SQL中使用的,可以在SELECT等SQL语句中调用,而存储过程不行.执行的本质都一样. 函数限制比较多,如不能用临时表,只能用表变量等,而存储过程的限制相对就比较少. 1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强. 2. 对于存储过程来说可以返回参数,而函数只

SQLServer 事务复制中使用脚本添加某个对象的发布

原文:SQLServer 事务复制中使用脚本添加某个对象的发布 -- use [发布库] --添加表:创建项目并将其添加到发布中 exec sp_addarticle @publication = N'ReplicationName', @article = N'MyObject', @source_owner = N'dbo', @source_object = N'MyObject', @destination_owner = N'dbo', @destination_table = N'M

Mysql之视图 触发器 事务 存储过程 函数

视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,可以将该结果集当做表来使用. 使用视图我们可以把查询过程中的临时表摘出来,用视图去实现,这样以后再想操作该临时表的数据时就无需重写复杂的sql了,直接去视图中查找即可,但视图有明显地效率问题,并且视图是存放在数据库中的,如果我们程序中使用的sql过分依赖数据库中的视图,即强耦合,那就意味着扩展sql极为不便,因此并不推荐使用 #两张有关系的表 mysql> se

Java学习总结(十八)——MySQL数据库(4)MySQL数据库中的视图,函数,存储过程中常见循环

一.MySQL存储过程中常见的循环1.while循环:WHILE.....DO.....END WHILE例1:创建存储过程(求1+2+.......+num的和):创建成功,进行调用:显示结果:2.REPEAT循环: REPEAT.........UNTLL END REPEAT例2:创建存储过程:创建完成,调用存储过程:显示结果:3.LOOP循环:LOOP END LOOP 例3:创建存储过程:创建成功,调用存储过程:显示结果:二.MySQL中的视图1.概念:有结构(有行有列),但没有结果(

Mysql学习---视图/触发器/存储过程/函数/索引 180101

视图 视图: 视图是一个虚拟表(非真实存在),动态获取数据,仅仅能做查询操作 本质:[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用.由于视图是虚拟表,所以无法使用其对真实表进行创建.更新和删除操作,PyMysql是支持视图的. 仅能做查询用. 创建视图: create VIEW stu as select * from student; # 这里只是建立了一个对应关系,视图是虚表,动态获取数据 select * from stu;

查询sqlserver数据库视图、存储过程等包含特定的字符串

? 1 2 3 4 5 6 SELECT  A.name ,         B.definition FROM    SYS.objects A         INNER JOIN sys.sql_modules B ON A.object_id = B.object_id                                         AND ( CHARINDEX('包含字符',                                               

查看SQL SERVER 加密存储过程,函数,触发器,视图

原文:查看SQL SERVER 加密存储过程,函数,触发器,视图 create  PROCEDURE sp_decrypt(@objectname varchar(50))ASbeginset nocount on--CSDN:j9988 copyright:2004.07.15 --V3.2 --破解字节不受限制,适用于SQLSERVER2000存储过程,函数,视图,触发器--修正上一版"视图触发器"不能正确解密错误--发现有错,请E_MAIL:[email protected]be

PostgreSQL更新视图脚本的注意事项

项目最早是基于Oracle的,移植到PostgreSQL后,本着尽量少修改的原则,创建/更新视图的脚本也沿用了Oracle风格的CREATE OR REPLACE VIEW形式.但是每当要更新视图定义时,常常报"cannot change name of view column xxx to yyy"的错误,通常是在视图修改某字段名.中间增加字段.删除字段时发生. 究其原因,是PostgreSQL虽然支持CREATE OR REPLACE VIEW语义,却有着容易让人忽略的重要限制(O