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;

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

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...