Csa*_*oth 6 sql-server-2005 sql-server best-practices shrink
序言:总的来说,这是一个很大的禁忌,但相信我,在真正需要空间的情况下,这种情况很少见。例如 Express Edition 限制为 10GB。想象一下,您发现通过数据类型转换(blob 列)可以释放大量空间。但在那之后,DB 文件的大小仍然和我们知道的一样,10GB 的限制也没有神奇地改变。所以需要某种收缩。那是一个例子。
在我的测试环境中,我执行了:
DBCC SHRINKFILE (DBFile, NOTRUNCATE)
DBCC SHRINKFILE (DBFile, TRUNCATEONLY)
Run Code Online (Sandbox Code Playgroud)
这确实有效(我知道这会最大限度地减少可用空间,在现实世界中我会留下可用空间)。花了很多小时才完成。正如我们所知,它是一个单线程进程奇怪的行为 DBCC Shrinkfile,“它作为一系列非常小的系统事务工作,因此没有什么可回滚的。” - 保罗兰达尔http://www.sqlservercentral.com/Forums/Topic241295-5-1.aspx。我们也知道它搞乱了索引碎片时间http://www.mssqltips.com/sqlservertip/2055/issues-with-running-dbcc-shrinkfile-on-your-sql-server-data-files/和我可以确认。尽管在http://www.karaszi.com/SQLServer/info_dont_shrink.asp 中有描述,但我没有遇到日志文件增长
我发布了一些INDEX REBUILD
,REORGANIZE
而那些在几秒钟内就完成了。
我的问题:
DBCC SHRINKFILE (DBFile, NOTRUNCATE)
所以我只需要DBCC SHRINKFILE (DBFile, TRUNCATEONLY)
吗?我有一种感觉,两者在不同的逻辑层面上工作,但我不得不问这个。底线:我保证我不会定期收缩或做任何事情。但这是一个上限被击中并需要收缩的情况。
回答我的第二个问题:我没有遇到事务日志文件增长,因为我在开发人员测试环境中摆弄。事务日志文件会在生产环境中增长(假设完全恢复模型)。您也应该在您的测试环境中模仿它。tr 日志文件的增长实际上大于您可以在数据库文件中释放的空间。最后,您不仅要收缩数据库文件,还要收缩事务日志(如何以及何时这样做取决于恢复模型)。我看到的生产环境有如此严重的索引碎片,它可以变得更好。我的脚本重新索引每个碎片级别高于 30% 的索引。
为了应对增长,您可能必须在进行一生一次的转换时从完全恢复切换到简单。但这会破坏备份链。
回答我的第三个问题:在 DB 文件收缩后进行重新索引/索引重建,因为收缩会弄乱索引碎片。
我还没有试验过所有这些如何影响查询统计信息。
脚本重新索引:见实施例d的TechNet sys.dm_db_index_physical_stats(的Transact-SQL) 。一篇关于增量收缩的文章,会引出其他有价值的内容:http : //www.mssqltips.com/sqlservertip/3178/incrementally-shrinking-a-large-sql-server-data-file-using-powershell
Aar*_*and 14
如果你想:
前进。既然你说你只会在极少数情况下这样做,我不确定你在这里寻找什么答案。你想要一个大大的赞,你可以忽略你读过的一切并掷骰子吗?
我至少建议一件事:如果您有 10GB 的数据,就会在 Express 中达到 10GB 的限制。您可以通过删除数据文件中的数据(或将数据分散到多个数据库中)来避免这种情况。如果您释放数据文件中的一堆空间,该空间将被重用(如果你删除了一个表,这将是自动的;如果你删除了行或更改了列结构,你将需要重建——这至少也会临时占用一些空间)。因此,如果您释放文件中的 5GB 数据,仅仅因为文件是 9GB 并不意味着如果您添加 2GB,它会尝试变成 11GB - 它会重复使用文件中的空间,直到找不到更多空间。将文件缩小到 4GB,然后强制它增长以容纳新数据将是一个昂贵得多的操作。这就像洗一条已经干净的毛巾,你将用它来擦掉一团糟......
归档时间: |
|
查看次数: |
6096 次 |
最近记录: |