将当前数据库里所有存储过程的内容进行批量替换方案

Posted 码写人生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将当前数据库里所有存储过程的内容进行批量替换方案相关的知识,希望对你有一定的参考价值。

将当前数据库里所有存储过程里的内容进行批量替换方案
  1. 备份存储过程
USE [MyDB]  
go   
 
IF OBJECT_ID(master..all_proc_before_replace, U) IS NOT  NULL   
    DROP TABLE master..all_proc_before_replace  
  
    SELECT  o.name AS proc_name,  
            definition ,  
            o.type ,  
              AS remark  
    INTO    master..all_proc_before_replace   --- 做备份,备份到master..all_proc_before_replace   
    FROM    sys.sql_modules s ,  
            sys.objects o  
    WHERE   o.object_id = s.object_id  
            AND o.type = P -- 只指定过程  
            AND o.name not  LIKE pr[_]fm[_]% --剔除掉含fM相关过程  
            AND s.definition IS NOT NULL --未加密的过程  
go 
  1.  替换

 

SET ANSI_NULLS ON  
GO  
SET QUOTED_IDENTIFIER ON   
GO  
--创建表to_replace_create_proc_error 收集执行替换后的过程报错信息   
IF OBJECT_ID(master..to_replace_create_proc_error, U) IS NOT  NULL 
    DROP TABLE master..to_replace_create_proc_error  
CREATE TABLE master..to_replace_create_proc_error
    (
      proc_name NVARCHAR(128) ,
      definition NVARCHAR(MAX) ,
      errormsg NVARCHAR(MAX)
    )  
  
  
  
  
DECLARE @proc_name NVARCHAR(128) ,
    @definition NVARCHAR(MAX)   
DECLARE c CURSOR FAST_FORWARD  
FOR  
SELECT  proc_name ,  
definition  
FROM    master..all_proc_before_replace   
WHERE  proc_name NOT  LIKE pr[_]fm[_]%
 --剔除掉停职fm相关过程  
          
OPEN c   
FETCH NEXT FROM C INTO @proc_name, @definition   
WHILE @@FETCH_STATUS = 0 
    BEGIN   
          
        IF @definition LIKE %tempdb% --符合条件的过程,进行替换  
            BEGIN   
                SET @definition = REPLACE(@definition, 表名, TableName)  
                        -- 此处可以进行多次 set @definition = REPLACE(@definition, ‘一‘, ‘壹‘)  
                        --SET @definition = REPLACE(@definition, ‘中心‘, ‘tempdb..#‘)  
                        --SET @definition = REPLACE(@definition, ‘tempdb..#WFPUSER#‘, ‘master..#WFPUSER#‘)  
                BEGIN TRY   
                    BEGIN TRANSACTION drop_create_proc    
                    EXEC (  DROP PROC [ + @proc_name +] ) -- 先DROP  
                    EXEC ( @definition )-- 再CREATE  
  
                    UPDATE  master..all_proc_before_replace -- 将已经替换后执行成功的,进行标记     
                    SET     remark = Y
                    WHERE   proc_name = @proc_name   
                    COMMIT TRANSACTION drop_create_proc  
          
                END TRY   
                BEGIN CATCH   
                    ROLLBACK TRANSACTION drop_create_proc  
                    INSERT  INTO master..to_replace_create_proc_error   --将已经替换后执行不成功的,收集报错信息内容  
                            SELECT  @proc_name ,
                                    @definition ,
                                    ERROR_MESSAGE()  
                END CATCH   
            END   
        FETCH NEXT FROM C INTO @proc_name, @definition   
         
    END   
          
CLOSE c  
DEALLOCATE c   
  
  
  
IF EXISTS ( SELECT  *
            FROM    master..to_replace_create_proc_error ) 
    BEGIN   
                ---- 返回报错,便于查找  
        RAISERROR 999999  本数据库中,有过程对象未替换完成,请手工处理   
    END   

 

 

以上是关于将当前数据库里所有存储过程的内容进行批量替换方案的主要内容,如果未能解决你的问题,请参考以下文章

织梦批量修改栏目的保存目录和文章命名规则

文档中如何批量替换所有的英文双引号为中文双引号,同时保证引号中的文字内容不变?

SQl Server 2005怎么批量替换用户名

在word中去掉所有括号中的不同内容,有简单方法吗

linux批量替换指定文件夹中所有文件的指定内容

如何用SQL语句将数据批量插入数据库