如何修改 SQL Server Management Studio 中自动生成的脚本文件的默认文件名格式?

Nic*_*ung 5 ssms sql-server-2008

我们的数据库包含大约 600 个存储过程和函数。我们正在尝试更好地管理数据库脚本的更改,而无需购买任何额外的软件。

我们希望使用> Tasks > Generate ScriptsSQL Server Management Studio 中的功能为数据库中的每个存储过程和函数自动生成单独的文件。

本文几乎总结了我们实现这一目标所采取的步骤:http://earljon.wordpress.com/2008/04/10/sql-server-2005-scripting-each-objects-to-a-separate-file/

我们遇到的唯一问题是 Management Studio 用于文件名的默认命名约定。它将脚本类型作为后缀添加到文件名的末尾,例如 sodbo.Name.StoredProcedure.sqldbo.Name.UserDefinedFunction.sql. 我们想要更改它,因此文件名是SP_Name.sqlFN_Name.sql

是否可以在 SQL Server Management Studio 中自定义输出文件名格式?我们希望向导输出此文件名约定,而不是必须使用单独的软件来批量重命名它们。

谢谢,尼克

Luk*_*kek 7

powershell脚本rename.ps1,在包含要重命名的文件的文件夹中运行:

Get-ChildItem -Filter "*.Table.sql" |Rename-Item -NewName {$_.name -replace '.Table.sql','.sql'}
Get-ChildItem -Filter "*.UserDefinedFunction.sql" |Rename-Item -NewName {$_.name -replace '.UserDefinedFunction.sql','.sql'}
Get-ChildItem -Filter "*.StoredProcedure.sql" |Rename-Item -NewName {$_.name -replace '.StoredProcedure.sql','.sql'}
Get-ChildItem -Filter "*.View.sql" |Rename-Item -NewName {$_.name -replace '.View.sql','.sql'}
Run Code Online (Sandbox Code Playgroud)

Get-ChildItem -Filter " .Role.sql" |Rename-Item -NewName {$_.name -replace '.Role.sql','.sql'} Get-ChildItem -Filter " .Schema.sql" |Rename- Item -NewName {$ .name -replace '.Schema.sql','.sql'} Get-ChildItem -Filter "*.Synonym.sql" |Rename-Item -NewName {$ .name -replace '.Synonym.sql ','.sql'} Get-ChildItem -Filter " .UserDefinedTableType.sql" |Rename-Item -NewName {$_.name -replace '.UserDefinedTableType.sql','.sql'} Get-ChildItem -Filter " . UserDefinedTableType.sql" |Rename-Item -NewName {$_.name -replace '.UserDefinedTableType.sql','.sql'}


Pon*_*ife 2

SSMS 中没有设置可以控制这一点,因此您的选项是:

  • 编写脚本以在生成文件后重命名文件
  • 编写一个使用SMO生成脚本的脚本
  • 查找可让您控制文件名的第三方工具