sys.master_files不能准确展示Tempdb数据库大小

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: # 问题提出 老鸟这两周一直没有找到机会略菜鸟,因为菜鸟最近一直在参加百阿培训。这不,刚好菜鸟过完买买买的双十一回来,老鸟逮着机会劈头盖脸问道:“菜鸟啊,你去研究下为什么MSSQL Server系统视图sys.master_files不能准确展示Tempdb数据库数据文件大小啊?”。 # 场景复盘 菜鸟一脸懵逼:“什么?不准确,不会吧?我一直都是用它来统计数据库文件大小的啊,有什么问

问题提出

老鸟这两周一直没有找到机会略菜鸟,因为菜鸟最近一直在参加百阿培训。这不,刚好菜鸟过完买买买的双十一回来,老鸟逮着机会劈头盖脸问道:“菜鸟啊,你去研究下为什么MSSQL Server系统视图sys.master_files不能准确展示Tempdb数据库数据文件大小啊?”。

场景复盘

菜鸟一脸懵逼:“什么?不准确,不会吧?我一直都是用它来统计数据库文件大小的啊,有什么问题呀?”,菜鸟满脸茫然的开始咨询G哥。
为了便于观察,菜鸟先将Tempdb的数据文件初始大小设置为10MB

USE [master]
GO
ALTER DATABASE [tempdb] MODIFY FILE ( NAME = N'tempdev', SIZE = 10MB )
GO

查看tempdb数据库Disk Usage:Right click on tempdb => Reports => Standard Reports => Disk Usage
01.png

创建测试表并插入数据

use tempdb
go

if OBJECT_ID('dbo.test', 'U') is not null
    drop table dbo.test

GO
create table dbo.test
(
    id int identity(1,1) not null primary key
    ,large_column char(5120) not null
)
GO

set nocount on
declare
    @do int = 0
;
while @do < 2000
begin
    INSERT INTO dbo.test
    select REPLICATE(NEWID(), 5120/36)
    
    set @do = @do + 1;
end
GO
exec sys.sp_spaceused test

查看测试表大小为16MB
02.png

通过以下三种方式获取tempdb数据库文件大小:
系统视图:sys.master_files看到是10MB,sys.database_files得到是20MB;
查看Windows物理文件:Windows Explorer看到的是20MB;
GUI:通过GUI看到的Currently Allocated Space也是10MB。
GUI查看数据库空间的方法:
03.png
三种统计方法的对比图
04.png

“哇,果真耶,老鸟不愧是老鸟,对得起这个响当当的名号。但是到底哪个是正确的呢,数据库物理文件大小到底是10MB还是20MB?”,菜鸟带着这个疑问一番翻云覆雨后的研究后,终于知道了事情的真相。

原因分析

sys.master_files: 由于Tempdb是SQL Server每次启动时候重新创建,这个系统视图反应的是tempdb数据库文件的初始大小,MSSQL Server会采用异步方式来更新它。换话句话说,SQL Server每次启动会根据这个系统视图中记录的数据库文件大小来创建Tempdb,当我们手动修改数据库初始文件大小的时候,这个系统视图数据会被更新,比如:

USE [master]
GO
ALTER DATABASE [tempdb] MODIFY FILE ( NAME = N'tempdev', SIZE = 10MB )
GO

sys.database_files:这个系统视图展示的数据库文件大小是准确的,会被系统及时更新,但是在使用的时候,需要指定特定的数据库名称。
GUI方式获取数据库文件大小:通过Profiler工具跟踪发现,使用GUI方式实际上是从sys.master_files系统视图中获取的数据,所以对于Tempdb也不准确。
05.png
Windows Explorer:这种方式查看Windows空间占用情况是准确的。

参考链接:
[sys.master_files does not show accurate size information]
(https://connect.microsoft.com/SQLServer/feedback/details/377223/sys-master-files-does-not-show-accurate-size-information)

最后结论

sys.master_files只有在统计tempdb数据库时,无法拿到准确的数据库文件大小;sys.database_files可以拿到准确的数据库文件大小,但是需要指定到特定的数据库下;GUI方式在获取tempdb数据库文件大小背后实际上是通过sys.master_files系统视图获取的,所以,统计也不准确;通过Windows 方式获取的数据库文件大小是准确无误的。

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
SQL IDE NoSQL
tp5源码解析--Db操作
在TP5的框架使用过程中,Db类是一定会接触到的,上手不难,但若想随心所欲的用,还是需要了解一番。用了千次,却没看过一次源码,学习源码,起码对TP5这个框架使用更加得心应手,毕竟技术服务于业务,能够写出更简介、更方便、更有效的业务代码,本身就是一件身心愉悦的事儿;
115 0
|
关系型数据库 数据库
【DB吐槽大会】第46期 - PG copy不能跳过错误行
大家好,这里是DB吐槽大会,第46期 - PG copy不能跳过错误行
|
SQL 测试技术 Go
SQL Server系统视图sys.master_files不能正确显示数据库脱机状态
原文:SQL Server系统视图sys.master_files不能正确显示数据库脱机状态   最近发现在SQL Server数据库(目前测试过SQL Server 2008, 2012,2014,2016各个版本)中,即使数据库处于脱机(OFFLINE)状态,但是sys.master_files中依然显示是联机状态。
902 0
|
SQL Go 数据库
SQL Server使用sys.master_files计算tempdb大小不正确
原文:SQL Server使用sys.master_files计算tempdb大小不正确 一直习惯使用sys.master_files来统计数据库的大小以及使用情况,但是发现sys.master_files不能准确统计tempdb的数据库大小信息。
1154 0