赞
踩
1、重建大表的聚集索引
2、完整备份+日志备份一次
3、收缩数据文件(不是收缩数据库),收缩过程一开始先100M/次,过几次再调到500M,不要一次收缩好几G,要话很多时间的。
请问你是不是之前操作这个数据库的时候,有很多delete表的操作?
如果是的话,delete操作腾出来的空间是没有办法再利用起来的,所以删除表最好用truncate
原因是delete会锁住表中被删除的那部分空间,自然别人也就不能往里面写;
如果是这样,在尝试过楼上各种方法都不行之后,并且你的SQL Server 是2008 或者2008R2 或者2012
可以试试rebuild表 这可以消除表空间中 因为delete导致的锁的问题
SqlServer2008 r2数据库,数据文件太大了,谁知道,这里的保留,还有未使用,都是怎么来的么?
我最大的表有上亿条数据,保留有80多个g,但是实际数据大小只有40多g,还有40多g未使用,这些都占用磁盘空间,现在搞得磁盘都满了。。。自动收缩数据库只能收缩日志文件的一部分,mdf文件还是没怎么变小。。求救。。。
最直接的就是看哪些数据可以不用存储就直接删除了,设计系统时就应该考虑这些问题的
比如:考勤系统的每天打卡数据,3个月前的根本没有多在作用了就可以先备份后直接删除了
有一种可能是索引碎片的原因,另外就是非聚集索引占用的空间,你可以试一下先重建聚集索引,然后看看空间是否变小了很多
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。