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

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 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
AI 代码解读

查看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
AI 代码解读

查看测试表大小为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
AI 代码解读

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
目录
打赏
0
0
0
0
9296
分享
相关文章
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
134 82
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
218 42
MySQL生产环境迁移至YashanDB数据库深度体验
这篇文章是作者将 MySQL 生产环境迁移至 YashanDB 数据库的深度体验。介绍了 YashanDB 迁移平台 YMP 的产品相关信息、安装步骤、迁移中遇到的各种兼容问题及解决方案,最后总结了迁移体验,包括工具部署和操作特点,也指出功能有优化空间及暂不支持的部分,期待其不断优化。
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
161 25
云数据库:从零到一,构建高可用MySQL集群
在互联网时代,数据成为企业核心资产,传统单机数据库难以满足高并发、高可用需求。云数据库通过弹性扩展、分布式架构等优势解决了这些问题,但也面临数据安全和性能优化挑战。本文介绍了如何从零开始构建高可用MySQL集群,涵盖选择云服务提供商、创建实例、配置高可用架构、数据备份恢复及性能优化等内容,并通过电商平台案例展示了具体应用。
从 MySQL 到时序数据库 TDengine:Zendure 如何实现高效储能数据管理?
TDengine 助力广州疆海科技有限公司高效完成储能业务的数据分析任务,轻松应对海量功率、电能及输入输出数据的实时统计与分析,并以接近 1 : 20 的数据文件压缩率大幅降低存储成本。此外,taosX 强大的 transform 功能帮助用户完成原始数据的清洗和结构优化,而其零代码迁移能力更实现了历史数据从 TDengine OSS 与 MySQL 到 TDengine 企业版的平滑迁移,全面提升了企业的数据管理效率。本文将详细解读这一实践案例。
31 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等