sql-server – 如何快速收缩所有数据库的所有文件?
发布时间:2020-12-12 16:57:52 所属栏目:MsSql教程 来源:网络整理
导读:在SQL Server(本例中为2008)中,如何快速收缩实例上所有数据库的所有文件(包括日志和数据)?我可以通过SSMS并右键单击每个并选择任务 – 收缩,但我正在寻找更快的东西. 我编写了一些“创建数据库”脚本并忘记了它们的默认大小已经膨胀,并且在这个项目中不需要
在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; 复制该查询的输出并运行它以收缩所有文件. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |