在 SQL Server(本例中为 2008)中,如何快速收缩实例上所有数据库的所有文件,包括日志和数据?我可以通过 SSMS 并右键单击每个并选择 Tasks -> Shrink,但我正在寻找更快的东西。
我编写了一些“创建数据库”脚本并忘记了它们的默认大小已经膨胀,并且不需要为该项目中的这些文件保留那么多空间。
DBCC SHRINKDATABASE当您从 GUI 执行“Tasks -> Shrink”时,它实际上会在幕后发出命令。试试看。当对话框出现时,不要单击“确定”按钮。相反,单击“脚本”按钮。您将在查询窗口中看到该命令。将它与 sys.databases 上的查询结合起来(省略 master 和 msdb),您可以编写一个脚本来缩小所有数据库。
DBCC SHRINKDATABASE
例如(取自 jcolebrand 的评论):
SELECT 'USE [' + d.name + N']' + CHAR(13) + CHAR(10) + 'DBCC SHRINKFILE (N''' + mf.name + N''' , 0, TRUNCATEONLY)' + CHAR(13) + CHAR(10) + CHAR(13) + CHAR(10) FROM sys.master_files mf JOIN sys.databases d ON mf.database_id = d.database_id WHERE d.database_id > 4;
复制该查询的输出并运行它以缩小所有文件。