系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 数据库 > MsSql > 详细页面

SQL Server 数据库中的收缩数据库和文件操作

时间:2023-10-27来源:系统城装机大师作者:佚名

1. 概述

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

2. 自动收缩数据库

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

右击选择数据库 → 属性 → 在数据库属性对话框,选项 → 将自动收缩设置为 TRUE;

20220323

3. 手动收缩数据库

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

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

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

  • 展开数据库,右击要收缩的数据库;
  • 任务 → 收缩 → 单击数据库

20220323

20220323

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

4. 手动收缩文件

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

展开数据库,右击数据库;任务 → 收缩 → 单击文件

20220323

收缩操作文件界面,在收缩操作中,可选择释放未使用空间在释放未使用空间前重新组织页通过将数据迁移到同一文件组中的其他文件来清空文件,三选一来进行手动收缩文件操作;

到此这篇关于SQL Server 数据库之收缩数据库和文件的文章就介绍到这了

分享到:

相关信息

  • dbeaver配置SQL server连接实现

    一、需要java jdk环境,我用的比较新 二、dbeaver新建连接SQL server...

    2023-10-27

  • SQLServer实现Ungroup操作的示例代码

    我们经常在SQL Server中使用group by语句配合聚合函数,对已有的数据进行分组统计。本文主要介绍一种分组的逆向操作,通过一个递归公式,实现ungroup操作。代码和实现我们看一个...

    2023-10-27

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载