我有一堆存储过程名称。我想为每个存储过程导出创建脚本。什么是最好的方式来做到这一点?t-sql存储过程创建脚本
现在我手动选择SSMS中的存储过程并选择"Script stored procedure as -> Drop and Create to"
。这似乎很乏味。我希望有更好的方法来解决这个问题。谢谢。
我有一堆存储过程名称。我想为每个存储过程导出创建脚本。什么是最好的方式来做到这一点?t-sql存储过程创建脚本
现在我手动选择SSMS中的存储过程并选择"Script stored procedure as -> Drop and Create to"
。这似乎很乏味。我希望有更好的方法来解决这个问题。谢谢。
您可以在对象资源管理器中右键单击数据库并执行任务>生成脚本。
alt text http://i25.tinypic.com/2khmr8.png
这允许你选择一大堆对象被脚本(例如表,视图,存储的特效),你可以存储那些成一个单一的大SQL文件,或每个对象一个SQL文件。工作真的很好!
更新:,如果你想这样做在SQL Server Management Studio中的应用程序,你可以使用这个SQL脚本来查找存储的特效和定义 - 但是你不能有SQL Server的管理工作室写出来的文件磁盘,这不起作用 - 但你可以将结果复制到例如Excel中。
SELECT
pr.name ,
pr.type_desc ,
pr.create_date ,
mod.definition
FROM sys.procedures pr
INNER JOIN sys.sql_modules mod ON pr.object_id = mod.object_id
WHERE pr.Is_MS_Shipped = 0
如果您选择查看 - >摘要
然后点击“存储过程”,从对象资源管理器中它会为你提供的,你可以按Ctrl/Shift键选择所有的存储过程的列表(选择倍数)。 然后从那里你可以创建所有的脚本,然后创建所有的脚本。这是我用SSMS发现的许多怪癖之一。
注意:另一个很好的功能是过滤器选项,允许您轻松筛选存储/表格过程。只需右键单击对象资源管理器即可调出菜单。
感谢您通知有关过滤器功能。从我这里得到赞扬。 – stackoverflowuser 2010-07-20 17:43:07
要编写符合特定条件的所有符合条件,您可以使用类似下面的内容。
DECLARE @t VARCHAR(max) = '';
SELECT @t = @t +
'If OBJECT_ID(''' + QUOTENAME(OBJECT_SCHEMA_NAME(object_id)) + '.' + QUOTENAME(OBJECT_NAME(object_id)) + ''',''p'') IS NOT NULL
DROP PROCEDURE ' + QUOTENAME(OBJECT_SCHEMA_NAME(object_id)) + '.' + QUOTENAME(OBJECT_NAME(object_id)) + '
GO
SET ANSI_NULLS '
+ CASE
WHEN uses_ansi_nulls = 1 THEN 'ON'
ELSE 'OFF'
END
+ '
GO
SET QUOTED_IDENTIFIER '
+ CASE
WHEN uses_quoted_identifier = 1 THEN 'ON'
ELSE 'OFF'
END
+ '
GO
' + definition + '
GO
'
FROM [sys].[sql_modules]
WHERE OBJECTPROPERTY (object_id,'IsProcedure')=1
AND OBJECT_NAME(object_id) LIKE '%some_patttern%'
/*Stops the long text from getting truncated in SSMS*/
SELECT @t AS [processing-instruction(x)]
FOR XML PATH('')
这是如何工作的?我是否需要将@t设置为逗号分隔的存储过程名称列表? – stackoverflowuser 2010-07-20 17:36:47
@stack - 不,但你可以摆脱'LIKE',并使用'in'。 – 2010-07-20 17:39:51
真棒,正是我所需要的,不需要鼠标点击。 – dividius 2012-03-28 08:50:58
Visual Studio 2008数据库专业版和Visual Studio 2010 Professional(及更高版本)支持SQL Server 2005/2008的特殊项目类型。这些项目支持自动创建更改脚本,其中包含当前项目与指定目标数据库之间的所有更改。
AFAIK RedGate也提供了这样的工具,但我没有任何经验。
像这样的东西会帮助你。
使用动态sql和游标可以生成脚本,每个脚本都在一个单独的文件中,扩展名为.sql。
这个脚本会为他们的名字都提到:在第所有的程序生成脚本:
DECLARE @name varchar(100)
DECLARE @Definition varchar(max)
DECLARE @sql varchar(300)
DECLARE @schema varchar(10)
CREATE TABLE TEMPTABLE (ID INT IDENTITY(1,1), def varchar(max))
DECLARE script CURSOR
FOR
SELECT OBJECT_NAME(SYS.SQL_MODULES.OBJECT_ID), [DEFINITION] FROM SYS.SQL_MODULES
INNER JOIN SYS.OBJECTS ON SYS.OBJECTS.OBJECT_ID = SYS.SQL_MODULES.OBJECT_ID WHERE SYS.OBJECTS.TYPE='P'
--AND [NAME] IN('SOME PROC 1','SOME PROC 2','SOME PROC 3','SOME PROC 4') --<------ Mention Proc names you want to generate scripts for
OPEN script
FETCH NEXT FROM script INTO @name, @Definition
WHILE @@FETCH_STATUS = 0
BEGIN
FETCH NEXT FROM script INTO @name, @Definition
SET @schema = (select SYS.SCHEMAS.[NAME] from SYS.OBJECTS
INNER JOIN SYS.SCHEMAS ON SYS.OBJECTS.SCHEMA_ID = SYS.SCHEMAS.SCHEMA_ID
WHERE SYS.OBJECTS.[NAME]='' + @name + '')
SET @sql = 'IF EXISTS (SELECT * FROM ' + (@schema) +
'.PROCEDURES WHERE [NAME] = ''' + @name + ''')' + CHAR(10)
SET @sql = @sql + 'DROP PROCEDURE ' + @schema + '.' + @name + CHAR(10) + 'GO' + CHAR(10)
PRINT @sql
INSERT INTO TEMPTABLE VALUES(@sql + @definition)
SET @Sql = ('BCP "SELECT TOP 1 def FROM TEMPTABLE ORDER BY ID DESC" queryout "D:\' + @name + '.sql" -c -T')
EXEC XP_CmdShell @Sql --<---- Export to file
END
CLOSE script
DEALLOCATE script
SELECT * FROM TEMPTABLE --<----------- Optional
DROP TABLE TEMPTABLE
C:\>BCP "Select '--'+pr.name,
pr.type_desc, pr.create_date, pr.modify_date, CHAR(13)+mod.definition
from DATABASE_NAME.sys.objects pr
INNER JOIN DATABASE_NAME.sys.sql_modules mod ON pr.object_id = mod.object_id
where type='p'" queryout "C:/output.sql" -c -T -S SERVER_NAME
从命令提示符下执行...它会将所有存储过程返回到一个文件中,并带有创建/修改日期的SP上的时间戳
以下内容将为一组存储过程名称生成脚本。脚本将被保存为一系列.sql文件。将过程的名称插入到@Table中。
-- Script Multiple SPROC as drop and create
-- SPROCS to script
DECLARE @Table TABLE (Name VARCHAR(MAX));
INSERT INTO @Table (Name) VALUES ('StoredProcedure1'), ('StoredProcedure2')
-- Drop TempTable if extant: http://stackoverflow.com/questions/659051/check-if-a-temporary-table-exists-and-delete-if-it-exists-before-creating-a-temp
IF OBJECT_ID('tempdb..##Temp') IS NOT NULL DROP TABLE dbo.##Temp
-- Loop through SPROCs
-- Cursor: https://www.mssqltips.com/sqlservertip/1599/sql-server-cursor-example/
-- Substring: http://stackoverflow.com/questions/4662496/trim-left-characters-in-sql-server
DECLARE @item VARCHAR(MAX); -- SPROC Name
DECLARE db_cursor CURSOR FOR
SELECT Name FROM @Table WHERE 1=1
OPEN db_cursor
FETCH NEXT FROM db_cursor INTO @item
WHILE @@FETCH_STATUS = 0
BEGIN
-- Execute
-- Print to file using Temp Table: http://stackoverflow.com/questions/10568975/can-i-specify-an-input-sql-file-with-bcp
-- Script SPROC via XML: http://stackoverflow.com/a/3292693/5301903
-- ANSI_NULLS and QUOTED_IDENTIFIER retain current settings.
-- Prepare Temp Table
SELECT
'IF EXISTS(SELECT * FROM sys.procedures WHERE Name = '''+Object_name(object_id)+''')
DROP PROCEDURE [dbo].['+Object_name(object_id)+']
GO
SET ANSI_NULLS '+CASE WHEN CAST(ISNULL(OBJECTPROPERTYEX(object_id,N'ExecIsAnsiNullsOn'),0) AS bit) = 1 THEN 'ON' ELSE 'OFF' END+'
GO
SET QUOTED_IDENTIFIER '+CASE WHEN CAST(ISNULL(OBJECTPROPERTYEX(object_id,N'ExecIsQuotedIdentOn'),0) AS bit) = 1 THEN 'ON' ELSE 'OFF' END+'
GO
' + definition + '
GO' AS Text
INTO dbo.##Temp
FROM [sys].[sql_modules]
WHERE 1=1
--AND OBJECTPROPERTY (object_id,'IsProcedure')=1
--AND OBJECTPROPERTY (object_id,'IsTable')=1
--AND Object_name(object_id) LIKE @name
AND Object_name(object_id) = @item
-- Print to text https://social.msdn.microsoft.com/Forums/en-US/71aefd98-ee46-48fe-a129-60791c583555/output-results-to-text-file-using-tsql?forum=transactsql
DECLARE @CMD VARCHAR(1000) = 'bcp "SELECT * FROM ##Temp" queryout C:\temp\'[email protected]+'.sql -c -T -S '+ @@servername
EXECUTE Master.dbo.xp_CmdShell @Cmd
-- Clean up
DROP TABLE dbo.##Temp
-- End Execute
FETCH NEXT FROM db_cursor INTO @item
END
CLOSE db_cursor
DEALLOCATE db_cursor
thanks marc。其实我有一堆SSRS报告和一个实用程序来提取存储的proc名称。由于会有更多的这些报告频繁进入,我正在考虑一个t-sql脚本,它可以获取存储过程的列表并生成一个脚本文件。那可能吗? – stackoverflowuser 2010-07-20 17:24:02
谢谢。正是我在找什么。 – stackoverflowuser 2010-07-20 17:33:51