SQL Server 数据库之收缩数据库和文件

收缩数据库和文件

1. 概述

当数据库随着时间而越来越大时,可对数据库进行收缩操作;
收缩数据文件通过将数据页从文件末尾移动到更靠近文件开头的未占用的空间来恢复空间,在文件末尾创建足够的空间后,可取消对文件末尾的数据页的分配并将它们返回给文件系统;

2. 自动收缩数据库

SQL Server 数据库支持自动收缩数据库和用户手动收缩数据库两种方式;
为提高数据库的使用效率,SQL Server 会寻找可用的数据库并找出第一个配置为自动收缩的数据库,它将检查该数据库,并在需要时收缩该数据库;
待一个数据库收缩完成后,系统会等待几分钟再检查下一个配置为自动收缩数据库,即 SQL Server 不会同时坚持所有数据库,也不会同时收缩所有数据库,它将以循环方式处理各个数据库,以负载在时间上错开;
若用户需要 SQL Server 数据库系统自动对数据库进行收缩,只需为该数据库设置自动收缩功能即可;
操作步骤如下所示:

  • 右击选择数据库 → 属性 → 在数据库属性对话框,选项 → 将自动收缩设置为 TRUE;《SQL Server 数据库之收缩数据库和文件》

3. 手动收缩数据库

用户还能手动对数据库进行收缩,但手动收缩数据库有一定的限制和局限;
主要的表现有如下几个方面:

  1. 收缩后的数据库不能小于数据库的最小大小 ;最小大小在数据库创建时指定的大小,或者上一次使用文件大小更改操作设置的大小;
  2. 不能在备份数据库时收缩数据库;反之,也不能在数据库执行收缩时备份数据库;
  3. 遇到内存游湖的列存储索引时,DBCC SHRINKDATABASE 操作将会失败;遇到 columnstore 索引之前完成的工作将会成功,所以数据库可能会较小;若要完成 DBCC SHRINKDATABASE,则需要执行 DBCC SHRINKDATABASE前禁用所有列的存储索引,再重新生成列存储的索引;

手动收缩数据库可在 SSMS 工具的对象资源管理器中完成,具体步骤如下:

  • 展开数据库,右击要收缩的数据库;
  • 任务收缩 → 单击数据库
    《SQL Server 数据库之收缩数据库和文件》
    《SQL Server 数据库之收缩数据库和文件》
    在收缩数据界面展示的是数据库 srs 的基本信息,若需要进行收缩操作,需要先选中在释放未使用的空间前重新组织文件。选中此项可能会影响性能(R),再收缩后文件中的最大可用空间中选择收缩后的空间,单击确定,即可完成手动收缩数据库操作;

4. 手动收缩文件

手动收缩文件跟手动收缩数据库操作类似;
在 SSMS 工具对文件的对象资源管理器中完成,具体步骤如下:

  • 展开数据库,右击数据库;
  • 任务收缩 → 单击文件《SQL Server 数据库之收缩数据库和文件》
    收缩操作文件界面,在收缩操作中,可选择释放未使用空间在释放未使用空间前重新组织页通过将数据迁移到同一文件组中的其他文件来清空文件,三选一来进行手动收缩文件操作;
    原文作者:菇毒
    原文地址: https://blog.csdn.net/weixin_43960383/article/details/124132494
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞