SQL Server查询数据库空间分配情况、数据库备份信息
查询数据库空间分配情况:
use master
go
create procedure dbo.proc_getdbspaceused
as
begin
set nocount on
create table #dbsize(
database_id int
,database_name nvarchar(1024)
,size_kb bigint
,space_available_kb bigint
,reserved_kb bigint
,data_kb bigint
,index_kb bigint
,unused_kb bigint
) declare @database_id int
declare @name nvarchar(1024)
declare @sql nvarchar(max)
declare cur cursor for select database_id,name from master.sys.databases order by database_id
open cur
fetch next from cur into @database_id,@name
while @@fetch_status=0
begin
set @sql =N'
insert into #dbsize
select
database_id = '+CONVERT(nvarchar(10),@database_id)+',
database_name = '''+@name+''',
size_kb = ((dbsize + logsize) * 8192 / 1024),
space_available_kb = (case when dbsize >= reservedpages then ((dbsize-reservedpages)* 8192/ 1024) else 0 end),
reserved_kb = (reservedpages * 8192 / 1024),
data_kb = (pages * 8192.0 / 1024),
index_kb = ((usedpages - pages) * 8192 / 1024),
unused_kb = ((reservedpages - usedpages) * 8192 / 1024)
from(
select
dbsize = sum(convert(bigint,case when status & 64 = 0 then size else 0 end)) ,
logsize = sum(convert(bigint,case when status & 64 <> 0 then size else 0 end))
from ['+@name+'].dbo.sysfiles
) t1,(
select
reservedpages = sum(a.total_pages),
usedpages = sum(a.used_pages),
pages = sum(
CASE
When it.internal_type IN (202,204,211,212,213,214,215,216) Then 0
When a.type <> 1 Then a.used_pages
When p.index_id < 2 Then a.data_pages Else 0
END )
from ['+@name+'].sys.partitions p
inner join ['+@name+'].sys.allocation_units a on p.partition_id = a.container_id
left join ['+@name+'].sys.internal_tables it on p.object_id = it.object_id
)t2'
exec(@sql)
fetch next from cur into @database_id,@name
end
close cur
deallocate cur select * from #dbsize
end
go
exec master.dbo.proc_getdbspaceused
查询数据库备份信息:
-- drop table #dbsize
-- drop table #logsize
create table #dbsize(
database_id int
,database_name nvarchar(1024)
,size_kb bigint
,space_available_kb bigint
,reserved_kb bigint
,data_kb bigint
,index_kb bigint
,unused_kb bigint
)
go
create table #logsize(
database_name nvarchar(1024)
,LogSize_MB decimal(24,8)
,LogSpaceUsed decimal(14,8)
,Status tinyint
)
go
insert into #dbsize exec master.dbo.proc_getdbspaceused
go
insert into #logsize exec('DBCC sqlperf(logspace)')
go
select t0.database_id,t0.database_name
,t0.size_kb/1024 as [数据库大小MB]
,t0.space_available_kb/1024 as [可用空间MB]
,LogSize_MB as [日志大小MB]
,LogSpaceUsed as [日志已使用%]
,t1.compatibility_level as [兼容级别]
,t1.collation_name as [校对规则]
,t1.recovery_model_desc as [恢复模式]
,(case t3.type/*btype*/ when 'D' then '完整' when 'I' then '差异' when 'L' then '日志' end)as [备份模式]
,最近备份时间,备份大小MB,备份耗时Min,备份目录
from #dbsize t0
inner join master.sys.databases t1 on t0.database_name=t1.name and t1.state_desc='ONLINE'
inner join #logsize t2 on t0.database_name=t2.database_name
--LEFT JOIN (select btype from (values('D'),('I'),('L')) as btype(btype)) t4 on 1=1
left join (
select a.database_name,a.type
,CONVERT(varchar(30),a.backup_start_date,120) AS 最近备份时间
,convert(decimal(18,2),compressed_backup_size/1024/1024.) as 备份大小MB
,DATEDIFF(MINUTE,backup_start_date,backup_finish_date) as 备份耗时Min
,REVERSE(stuff(REVERSE(physical_device_name),1,CHARINDEX('\',REVERSE(physical_device_name))-1,'')) as 备份目录
from msdb.dbo.backupset a
inner join (
select database_name,type,MAX(backup_start_date) as latest_backup_date
from msdb.dbo.backupset
group by database_name,type
)b on a.database_name=b.database_name and a.type=b.type and a.backup_start_date=b.latest_backup_date
left join msdb.dbo.backupmediafamily c on a.media_set_id=c.media_set_id
)t3 on t0.database_name=t3.database_name --and t2.btype=t3.type
go
SQL Server查询数据库空间分配情况、数据库备份信息的更多相关文章
- 数据库表设计时一对一关系存在的必要性 数据库一对一、一对多、多对多设计 面试逻辑题3.31 sql server 查询某个表被哪些存储过程调用 DataTable根据字段去重 .Net Core Cors中间件解析 分析MySQL中哪些情况下数据库索引会失效
数据库表设计时一对一关系存在的必要性 2017年07月24日 10:01:07 阅读数:694 在表设计过程中,我无意中觉得一对一关系觉得好没道理,直接放到一张表中不就可以了吗?真是说,网上信息什么都 ...
- SQL server学习(一)数据库的基本知识、基本操作(分离、脱机、收缩、备份、还原、附加)和基本语法
在软件测试中,数据库是必备知识,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数据库脱机.联机操作 数据库收缩操作 ...
- 关于SQL Server 2005 的自动远程数据库备份
原文:(原创)关于SQL Server 2005 的自动远程数据库备份 由于项目需要,需要对目标服务器上的数据库每天进行备份并转移,查阅网上的一些帮助,结合自己的实际需要,写了这篇文章,希望对有同样需 ...
- 使用SQL Server 2008的事务日志传送功能备份数据库(logshiping)
使用SQL Server 2008的事务日志传送功能备份数据库(logshiping) 使用SQL Server 2008的事务日志传送功能备份数据库(logshiping)
- SQL server学习(一)数据库的基本知识、基本操作和基本语法
在软件测试中,数据库是必备知识,假期闲里偷忙,整理了一点学习笔记,共同探讨. 阅读目录 基本知识 数据库发展史 数据库名词 SQL组成 基本操作 登录数据库操作 数据库远程连接操作 数据库分离操作 数 ...
- 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析
对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...
- SQL SERVER统计服务器所有的数据库(数据库文件)、表(表行数)、字段(各字段)等详细信息
原文:SQL SERVER统计服务器所有的数据库(数据库文件).表(表行数).字段(各字段)等详细信息 USE STAT GO SET NOCOUNT ON IF EXISTS(SELECT 1 FR ...
- sql server 备份与恢复系列八 系统数据库备份与恢复分析
一.概述 在前面讲过"sql server 备份与恢复系列"都是集中在用户数据库上.sql server还维护着一组系统数据库,这些系统数据库对于服务器实例的运行至关重要.在每次进 ...
- SQL Server 2008 错误15023:当前数据库中已存在用户或角色
解决SQL Server 2008 错误15023:当前数据库中已存在用户或角色,SQLServer2008,错误15023,在使用SQL Server 2008时,我们经常会遇到一个情况:需要把一台 ...
随机推荐
- git工具的安装和使用
啰嗦几句: 世界上本没有后悔药,但软件开发提供了后悔药,那就是代码管理工具.它可以让你的代码穿越回以前的状态,甚至可以指定某一个时刻,而且还可以穿越回来. 当下流行的代码管理工具有 SVN 和 GIT ...
- less使用方法总结
1 变量 我们常常在 CSS 中 看到同一个值重复多次,这样难易于代码维护. 理想状态,应是下面这样: const bgColor="skyblue"; $(".post ...
- mysql中间件研究(tddl atlas cobar sharding-jdbc)
mysql-proxy是官方提供的mysql中间件产品可以实现负载平衡,读写分离,failover等,但其不支持大数据量的分库分表且性能较差.下面介绍几款能代替其的mysql开源中间件产品,Atlas ...
- web产品浏览器兼容性问题你有考虑到吗?
通常,动态网页除了Server端的代码撰写Client端代码也必须下不少工夫.例如:表单提交前的数据验证.图片的轮播.菜单的收合等等. 因此,对于Client端是否能正常执行指令码也必须适当的考察,然 ...
- 使用CablleStatement调用存储过程
/** * 使用CablleStatement调用存储过程 * @author APPle * */ public class Demo1 { /** * 调用带有输入参数的存储过程 * CALL p ...
- bootstrap fileinput控件 + django后台上传、回显简单使用
一.控件下载:https://github.com/kartik-v/bootstrap-fileinput/ 官网:http://plugins.krajee.com/file-input 需要引入 ...
- vi 编辑器的日常使用
命令行模式: 光标管理 text 屏幕 行 单词 gg 跳转到文档头部 H 跳转到屏幕首行 ^ 或 数字0 跳转到行首 w 向前 G 跳转到文档尾部 M 跳转到屏幕中行 $ 跳转到行尾 b 向后 ...
- C++递归方法实现全排列
#include<iostream> using namespace std; void perm(int list[],int k,int m);//声明 void perm(int l ...
- 【Python 学习】通过while循环和for循环猜测年龄
Python中可以通过while和for循环来限制猜测年龄的次数 1. 在猜测年龄的小程序中,不加循环的代码是这样的: age_of_yu = 23 guess_age = int(input(&qu ...
- C 语言中函数的跳转
1.同一个函数内,可以使用goto语句: eg: void text_1( void ) { char i=0; a : i++; printf ( " text_1 = %d \r\n& ...