2021-02-06 21:34:26
我们知道SQL Server在8K 的页里存储数据。分区就是物理上连续的8个页。当我们创建一个数据库,数据文件会被逻辑分为页和区,当用户对象创建时,页会分配给它用来存储数据。GAM(Global Allocation Map)和SGAM(Shared Global Allocation Map)页用来跟踪SQL Server里空间分配情况。这里我们会一起讨论下SQL Server的空间分配,还有GAM和SGAM怎么帮助我们分配空间。
在SQL Server里有2类区:
统一区(Uniform Extent) :区属于一个用户对象。这些区的所有8页归一个对象所有。
混合区(Mixed Extent) :区属于各个用户对象。即区里的每个页都可以属于不同用户对象。
为了更好的管理空间分配,如果一个表或索引大小小于8页(即64k),SQL Server会分配混合区的页,而不是统一区的页。