목차
复制存储过程
Jun 07, 2016 pm 02:56 PM
m
sql
use
복사
저장
성명
프로세스
SQL语句复制存储过程 无 USE mastergoIF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = Object_id(N'[dbo].[sp_copyProce]') AND Objectproperty(id, N'IsProcedure') = 1) DROP PROCEDURE [dbo].[sp_copyProce]goCREATE PROC Sp_copyproce @s_dbname SY
SQL语句复制存储过程
USE master go IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = Object_id(N'[dbo].[sp_copyProce]') AND Objectproperty(id, N'IsProcedure') = 1) DROP PROCEDURE [dbo].[sp_copyProce] go CREATE PROC Sp_copyproce @s_dbname SYSNAME,--要复制存储过程的源数据库名 @d_dbname SYSNAME --目标数据库名 AS SET nocount ON IF Db_id(@s_dbname) IS NULL BEGIN RAISERROR('数据库"%s"不存在',1,16,@s_dbname) RETURN END IF Db_id(@d_dbname) IS NULL BEGIN RAISERROR('数据库"%s"不存在',1,16,@d_dbname) RETURN END SELECT @s_dbname = '[' + Replace(@s_dbname, ']', ']]') + ']', @d_dbname = '[' + Replace(@d_dbname, ']', ']]') + ']' --复制存储过程信息到临时表 CREATE TABLE #sys_syscomments_bak ( name SYSNAME, xtype CHAR(2), number SMALLINT, colid SMALLINT, status SMALLINT, ctext TEXT ) --select o.name,o.xtype,c.number,c.colid,c.status,c.ctext into #sys_syscomments_bak --from dbo.syscomments c,dbo.sysobjects o where 1=2 EXEC( 'insert #sys_syscomments_bak(name,xtype,number,colid,status,ctext) select o.name,o.xtype,c.number,c.colid,c.status,cast(c.ctext as varchar(8000)) from ' +@s_dbname+'.dbo.syscomments c,'+@s_dbname+'.dbo.sysobjects o where c.id=o.id and o.status>=0 and o.xtype=''P'' and not exists( select * from '+ @d_dbname+'.dbo.sysobjects where name=o.name)') --创建存储过程 DECLARE tb CURSOR local FOR SELECT 'use ' + @d_dbname + ' exec(''create proc dbo.[' + Replace(name, N']', N']]') + '] as --'') exec sp_recompile [' + Replace(name, N']', N']]') + ']' FROM #sys_syscomments_bak DECLARE @s NVARCHAR(4000) OPEN tb FETCH tb INTO @s WHILE @@fetch_status = 0 BEGIN EXEC(@s) FETCH tb INTO @s END CLOSE tb DEALLOCATE tb --复制存储过程结构 EXEC Sp_configure 'allow updates', 1 --reconfigure with override BEGIN TRAN EXEC('delete c from '+@d_dbname+'.dbo.syscomments c,'+@d_dbname+ '.dbo.sysobjects o,#sys_syscomments_bak ob where c.id=o.id and o.name=ob.name and o.xtype=ob.xtype insert '+@d_dbname+'.dbo.syscomments([id],[number],[colid],[status],[ctext]) select o.[id],ob.[number],ob.[colid],ob.[status],cast(cast(ob.[ctext] as varchar(8000)) as varbinary(8000)) from '+@d_dbname+ '.dbo.sysobjects o,#sys_syscomments_bak ob where o.name=ob.name and o.xtype=ob.xtype') COMMIT TRAN EXEC Sp_configure 'allow updates', 0 --reconfigure with override go
로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

인기 기사
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

인기 기사
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7297
9


자바 튜토리얼
1622
14


Cakephp 튜토리얼
1342
46


라라벨 튜토리얼
1259
25


PHP 튜토리얼
1206
29



Hibernate 프레임워크에서 HQL과 SQL의 차이점은 무엇입니까?

화웨이는 내년에 혁신적인 MED 스토리지 제품을 출시할 예정입니다. 랙 용량은 10PB를 초과하고 전력 소비량은 2kW 미만입니다.

MyBatis 동적 SQL 태그의 Set 태그 기능에 대한 자세한 설명
