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

 更新时间:2023年07月12日 09:13:08   作者:菇毒  
收缩数据文件通过将数据页从文件末尾移动到更靠近文件开头的未占用的空间来恢复空间,在文件末尾创建足够的空间后,可取消对文件末尾的数据页的分配并将它们返回给文件系统,本文给大家介绍SQL Server 数据库中的收缩数据库和文件的相关知识,一起看看吧

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 数据库之收缩数据库和文件的文章就介绍到这了,更多相关sqlserver收缩数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入C++ string.find()函数的用法总结

    深入C++ string.find()函数的用法总结

    本篇文章是对C++中string.find()函数的用法进行了详细的总结与分析,需要的朋友参考下
    2013-05-05
  • MSSQL Server 查询优化方法 整理

    MSSQL Server 查询优化方法 整理

    查询速度慢的原因很多,常见如下几种
    2010-03-03
  • sqlserver 使用SSMS运行sql脚本的六种方法

    sqlserver 使用SSMS运行sql脚本的六种方法

    这篇文章主要介绍了sqlserver 使用SSMS运行sql脚本的六种方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • SQL中Exists的用法

    SQL中Exists的用法

    这篇文章主要介绍了SQL中Exists的用法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • MSSQL中递归SQL查询语句实例说明-

    MSSQL中递归SQL查询语句实例说明-

    MSSQL中递归SQL查询语句分享,需要的朋友可以参考下。
    2011-09-09
  • SQL server 随机数函数

    SQL server 随机数函数

    在SQL server中,有个随机函数rand(),有不少新手可能不知道存在这个函数,现在我就把这个函数的一些随机数生成技巧写出来,这是面向菜鸟的,老鸟请不要拍砖呀,我的头还不够硬
    2009-07-07
  • 必须会的SQL语句(五) NULL数据处理和类型转换

    必须会的SQL语句(五) NULL数据处理和类型转换

    这篇文章主要介绍了sqlserver中NULL数据处理和类型转换方法,需要的朋友可以参考下
    2015-01-01
  • 删除Table表中的重复行的方法

    删除Table表中的重复行的方法

    在写SQL的时候经常会有这样的需求: 在一个Table中会有多条重复的数据,如何有效的取出来不重复的数据,或者是删除掉重复的数据,或者取出某列重复值的第一条数据.
    2010-06-06
  • Sql Server中判断表、列不存在则创建的方法

    Sql Server中判断表、列不存在则创建的方法

    这篇文章主要给大家分享了Sql Server中判断表、列是否存在,如果不存在则创建的方法,文章先给大家简单介绍了Sql Server中判断表中某列是否存在的方法,文中给出了详细的示例代码,需要的朋友们可以参考借鉴,下面来一起看看吧。
    2017-03-03
  • sql中的char与varchar有什么区别

    sql中的char与varchar有什么区别

    varchar使用起来较为灵活,节省了一定的空间,但是它在判断位数时也耗费了时间,从整个系统的性能角度来说,char数据类型处理的速度更快,有时甚至可以超出varchar处理速度的很多倍,本文给大家介绍
    sql中的char与varchar有什么区别,一起看看吧
    2023-10-10

最新评论