国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

將mater庫(kù)中的系統(tǒng)存儲(chǔ)過程批量生成*.sql文件 通用且非常實(shí)用

2024-08-31 00:57:43
字體:
供稿:網(wǎng)友
大家都知道系統(tǒng)存儲(chǔ)過程是無法用工具導(dǎo)出的(大家可以試試 >任務(wù)>生成SQL腳本)
因?yàn)橄到y(tǒng)存儲(chǔ)過程一般是不讓開發(fā)人員修改的。

需要知識(shí):

1、xp_cmdshell命令的使用
2、sp_MS_marksystemobject 標(biāo)記系統(tǒng)存儲(chǔ)過程的方法
3、dos 命令,如 type,>> 等
4、bcp 命令的使用

復(fù)制代碼 代碼如下:


use master
go
if OBJECT_ID('pr_procToSql') is not null drop proc pr_procToSql
go
create proc pr_procToSql
(
@服務(wù)器名 varchar(100)
,@用戶名 varchar(100)
,@密碼 varchar(100)
,@path varchar(200)
,@database varchar(200)
,@sysproc int='0' --是否標(biāo)記為系統(tǒng)函數(shù) 1:是,0:否
,@proc_name varchar(100)='' --默認(rèn)是所有,可以模糊搜索
,@savetype varchar(200)='.sql' --默認(rèn)保存為sql腳本
)
as
/*
版本:v1
作者:達(dá)摩
日期:2012-04-13
功能:
1/將master庫(kù)的系統(tǒng)存儲(chǔ)過程批量生成文件(系統(tǒng)存儲(chǔ)過程無法自動(dòng)導(dǎo)出)
2/可以將所有類型的存儲(chǔ)過程導(dǎo)出
3/可以標(biāo)記上系統(tǒng)存儲(chǔ)過程
調(diào)用:
exec pr_procToSql '.','sa','H4ymH@$RTd','e:/tom/master/','master','1',‘'
exec pr_procToSql '.','sa','a123456','e:/sql/','agt_trad','','pr_','.sql'
*/
set nocount on
declare @sp nvarchar(500),@s nvarchar(2000),@row int,@id int,@s_add varchar(2000)
set @s=' use '+@database
exec(@s)
if object_id('tempdb..#t') is not null drop table tempdb..#t
create table tempdb..#t(name varchar(2000)
, id int IDENTITY(1,1) not null
)
exec('
insert into tempdb..#t(name)
select name
--into TEMPDB..#T
from '+@database+'..sysobjects where xtype=''p'' and name like '''+@proc_name+'%''
')
select @row=COUNT(*) from tempdb..#t
print '共生成['+cast(@row as varchar)+']個(gè)存儲(chǔ)過程'
set @id=1
while @row>=@id
begin
select top 1 @sp=name from tempdb..#T where id=@id
if OBJECT_ID('tempdb..test') is not null drop table tempdb..test
--增加use master go
set @s_add='echo use ['+@database+']>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo IF EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N''[dbo].['+@sp+']'') AND type in (N''P'', N''PC''))>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo DROP PROCEDURE [dbo].['+@sp+']>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo SET ANSI_NULLS ON>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo SET QUOTED_IDENTIFIER ON>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
select @s='
select text into tempdb..test
from '+@database+'..syscomments
where id=OBJECT_ID('''+@database+'..'+@sp+''')
'
exec(@s)
--select * from tempdb..test
select @s='exec xp_cmdshell '+'''bcp tempdb..test out '+@path+@sp+cast(@id as varchar)+@savetype+' -c -S '+@服務(wù)器名+' -U '+@用戶名+' -P '+@密碼+''''
exec(@s)
--將前面加上use master 信息追加到 最前面
set @s_add='type '+@path+@sp+CAST(@id as varchar)+@savetype+'>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
if @sysproc='1'
begin
--在最后面加上標(biāo)記為系統(tǒng)存儲(chǔ)過程
set @s_add='echo exec sp_MS_marksystemobject ''['+@sp+']''>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
set @s_add='echo GO>>'+@path+@sp+@savetype
exec xp_cmdshell @s_add
print '標(biāo)記第['+cast(@id as varchar)+']個(gè)為系統(tǒng)存儲(chǔ)過程:'+@sp
end
set @s_add='del '+@path+@sp+CAST(@id as varchar)+@savetype
exec xp_cmdshell @s_add
print '生成第['+cast(@id as varchar)+']個(gè)存儲(chǔ)過程:'+@sp
delete from tempdb..#T where id=@id
set @id=@id+1
end


此存儲(chǔ)過程可以完善的功能
1、生成視圖
2、生成函數(shù)
3、生成指定庫(kù)的表結(jié)構(gòu)
4、生成指定庫(kù)的約束,用于批量生成升級(jí)腳本
5、用于生成數(shù)據(jù)庫(kù)中升級(jí)的腳本
歡迎大家?guī)臀蚁胂耄€有別的辦法嗎?希望加QQ282329611交流。

生成結(jié)果如圖:

將mater庫(kù)中的系統(tǒng)存儲(chǔ)過程批量生成*.sql文件 通用且非常實(shí)用

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 贞丰县| 中西区| 梨树县| 江安县| 红河县| 沿河| 晋宁县| 易门县| 天气| 林周县| 海盐县| 云梦县| 友谊县| 安庆市| 汉寿县| 长葛市| 五大连池市| 屏东县| 汉中市| 洛隆县| 新闻| 合作市| 武威市| 乌什县| 德江县| 横峰县| 张北县| 胶南市| 凤山县| 南皮县| 舒城县| 师宗县| 宜良县| 红河县| 尼勒克县| 玉树县| 肥城市| 鄯善县| 浙江省| 阿坝县| 任丘市|