Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩

--数据库占用大小
EXEC sp_spaceused

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第1张图片

--查询所有表大小,大小倒序排序
SELECT
TableName = obj.name,
TotalRows = prt.rows,
[DataSize(KB)]=SUM(alloc.data_pages)*8, --这里返回的是数据页个数,1页是8K,所以乘以8
[DataSize(MB)]=SUM(alloc.data_pages)*8/1024.0,
[DataSize(GB)]=SUM(alloc.data_pages)*8/1024.0/1024.0,
[SpaceUsed(KB)] = SUM(alloc.used_pages)*8,--这里返回的是数据页个数,1页是8K,所以乘以8
[SpaceUsed(MB)] = SUM(alloc.used_pages)*8/1024.0,
[SpaceUsed(GB)] = SUM(alloc.used_pages)*8/1024.0/1024.0
FROM sys.objects obj
JOIN sys.indexes idx ON obj.object_id = idx.object_id
JOIN sys.partitions prt ON obj.object_id = prt.object_id
JOIN sys.allocation_units alloc ON alloc.container_id = prt.partition_id
WHERE obj.type = 'U' AND idx.index_id IN (0, 1)
--AND idx.object_id=OBJECT_ID('tablename') 
GROUP BY obj.name, prt.rows
ORDER BY TotalRows DESC

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第2张图片

查询磁盘空间的使用情况
各数据库数据文件大小
数据库日志文件的大小
数据库使用利用率大小

1、查询各个磁盘分区的剩余空间:

Exec master.dbo.xp_fixeddrives;

sql1111
Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第3张图片

2、查询数据库中的所有数据库名:

SELECT Name FROM Master..SysDatabases ORDER BY Name;

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第4张图片

3、查询某个数据库中所有的表名:

SELECT name FROM SysObjects Where XType=’U’ ORDER BY Name;

SELECT * FROM SysObjects Where XType=’U’ ORDER BY Name;

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第5张图片

4、查询数据库的数据文件及日志文件的相关信息(包括文件组、当前文件大小、文件最大值、文件增长设置、文件逻辑名、文件路径等)

select * from [数据库名].[dbo].[sysfiles];

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第6张图片

转换文件大小单位为MB:

select name, convert(float,size) * (8192.0/1024.0)/1024. from [数据库名].dbo.sysfiles;

5、查询当前数据库的磁盘使用情况:

Exec sp_spaceused;
exec sp_spaceused ‘表名’; –取得表占用空間

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第7张图片

6、查询数据库服务器各数据库日志文件的大小及利用率

DBCC SQLPERF(LOGSPACE);

Sql Server 查询数据库中数据表占用磁盘空间大小,数据库大小,日志压缩_第8张图片

7、收缩数据库日志文件(sql server2005)

backup log [数据库名] with no_log
DBCC SHRINKDATABASE(N’[数据库名], 15, TRUNCATEONLY)

8、收缩数据库日志文件(sql server2008)

USE[master]
 
ALTER DATABASE [数据库名] SET RECOVERY SIMPLE WITH NO_WAIT
 
ALTER DATABASE [数据库名] SET RECOVERY SIMPLE –简单模式
 
USE [数据库名]
 
DBCC SHRINKFILE (N’[数据库名]_Log’ , 11, TRUNCATEONLY)
 
USE[master]
 
ALTER DATABASE [数据库名] SET RECOVERY FULL WITH NO_WAIT
 
ALTER DATABASE [数据库名] SET RECOVERY FULL –还原为完全模式

你可能感兴趣的:(系统运维,数据库,恰饭,数据库,sql,sqlserver)