DBCC SHRINKDATABASE DBCC SHRINKFILE 没有反应 没有效果

当SQL Server提示Primary Filegroup已满,无法插入数据时,检查发现有unused空间。DBCC SHRINKDATABASE和DBCC SHRINKFILE无效。原因在于数据库设置的最大文件限制和数据文件已达到上限,导致其他表无法使用unused空间。数据碎片是OLTP系统中常见的问题,可通过重建聚集索引来释放空间。解决方案包括查询和整理碎片严重的表,创建聚集索引并定期维护。
摘要由CSDN通过智能技术生成

问题描述

========
用户使用INSERT语句插入数据但是SQL Server报告说Primary Filegroup已满无法写入数据。用户检查了sp_spaceused发现还有unused空间

问题范围

========

协助检查这个问题并确保Insert语句可以执行完成。

故障排查

========

1.我们通过执行DBCC SHRINKDATABASE和DBCC SHRINKFILE均没有效果

2.经过确认,客户将该数据库设置了“最大文件上限”为2125MB,而当前数据库文件大小为2124MB,已经不能继续增长

3.通过使用sp_spaceused查询,发现还有reserved和unused的空间

提问:既然我有大量unused的空间,为什么不能插入数据?既然我有大量的unused的空间为什么不能收缩数据库?

答:首先我对于sp_spaceused返回的结果进行解释:

需要注意的是:请把sp_spaceused后面的参数改成表,这样才能解释该问题。如果参数是数据库,只是一个数字总和,不能说明问题。

Unallocated space – 这部分空间已经存在在数据库文件中,但是没有给任何表使用,属于公共空间,以后谁都可以使用它。

Reserved – 为该表分配的总空间大小,是后面三者的

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值