sql-server – 如何快速收缩所有数据库的所有文件?

前端之家收集整理的这篇文章主要介绍了sql-server – 如何快速收缩所有数据库的所有文件?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
sql Server(本例中为2008)中,如何快速收缩实例上所有数据库的所有文件(包括日志和数据)?我可以通过SSMS并右键单击每个并选择任务 – >收缩,但我正在寻找更快的东西.

我编写了一些“创建数据库”脚本并忘记了它们的默认大小已经膨胀,并且在这个项目中不需要为这些文件保留那么多空间.

解决方法

当您从GUI执行“任务 – >收缩”时,它实际上会在幕后发出DBCC SHRINKDATABASE命令.试试吧.出现对话框时,请勿单击“确定”按钮.而是,单击“脚本”按钮.您将在查询窗口中看到该命令.将其与sys. databases上的查询相结合(省略master和msdb),您可以创建一个脚本来收缩所有数据库.

例如(取自jcolebrand的评论):

SELECT 
      'USE [' + d.name + N']' + CHAR(13) + CHAR(10) 
    + 'DBCC SHRINKFILE (N''' + mf.name + N''',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;

复制该查询输出并运行它以收缩所有文件.

猜你在找的MsSQL相关文章