SQL SERVER 查看数据库状态

本文介绍了三种查询SQL Server数据库属性的方法:通过数据库属性对话框、使用DATABASEPROPERTY函数及执行sp_helpdb存储过程。提供了详细的步骤及示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方法一:

右击数据库名字,然后点击属性。




方法二:使用DATABASEPROPERTY函数。

如查看数据库版本号,如下:

SELECT DATABASEPROPERTY ('Epiphany','Version'); 

执行如下图:


方法三:

sp_helpdb;

执行如下图:



完毕!

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------


SQL Server 2008 联机丛书
DATABASEPROPERTY (Transact-SQL)

语法

 
DATABASEPROPERTY ( database , property ) 

参数

database

一个表达式,包含要返回其命名属性信息的数据库名。 databasenvarchar(128)

property

一个表达式,包含要返回的数据库属性的名称。property 的数据类型为 varchar(128),可以是下列值之一:

说明返回的值

IsAnsiNullDefault

数据库遵循 ISO 规则,允许 Null 值。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAnsiNullsEnabled

所有与 Null 的比较将取值为未知。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAnsiWarningsEnabled

如果发生了标准错误条件,则将发出错误消息或警告消息。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAutoClose

数据库在最后一位用户退出后完全关闭并释放资源。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAutoCreateStatistics

如果表中数据更改造成统计信息过期,则自动更新现有统计信息。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAutoShrink

数据库文件可以自动定期收缩。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsAutoUpdateStatistics

启用自动更新统计信息数据库选项。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsBulkCopy

数据库允许无日志记录的操作。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsCloseCursorsOnCommitEnabled

提交事务时打开的游标已关闭。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsDboOnly

数据库处于仅 DBO-only 访问模式。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsDetached

分离操作分离了数据库。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsEmergencyMode

启用紧急模式,允许使用可疑数据库。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsFulltextEnabled

数据库已启用全文功能。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsInLoad

正在装载数据库。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsInRecovery

正在恢复数据库。

1 = TRUE

0 = FALSE NULL1 = 输入无效

IsInStandBy

数据库以只读方式联机,并允许还原日志。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsLocalCursorsDefault

游标声明默认为 LOCAL。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsNotRecovered

数据库不能恢复。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsNullConcat

Null 串联操作数产生 NULL。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsOffline

数据库脱机。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsParameterizationForced

PARAMETERIZATION 数据库 SET 选项为 FORCED。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsQuotedIdentifiersEnabled

可对标识符使用英文双引号。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsReadOnly

数据库处于只读访问模式。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsRecursiveTriggersEnabled

已启用触发器递归触发。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsShutDown

数据库启动时遇到问题。

1 = TRUE

0 = FALSE

NULL1 = 输入无效

IsSingleUser

数据库处于单用户访问模式。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsSuspect

数据库可疑。

1 = TRUE

0 = FALSE

NULL = 输入无效

IsTruncLog

数据库截断其登录检查点。

1 = TRUE

0 = FALSE

NULL = 输入无效

Version

创建数据库时使用的 Microsoft SQL Server 代码的内部版本号。标识为仅供参考。不提供支持。不保证以后的兼容性。

版本号 = 数据库处于打开状态。

NULL = 数据库关闭。

1 如果从未启动数据库,或者已经自动关闭数据库,则返回值也为 NULL。

返回类型

int

异常

出现错误时或调用方没有权限查看对象时,将返回 NULL。

在 SQL Server 中,用户只能查看其拥有的安全对象的元数据,或者已对其授予权限的安全对象的元数据。也就是说,如果用户对该对象没有任何权限,则那些会生成元数据的内置函数(如 OBJECT_ID)可能返回 NULL。有关详细信息,请参阅元数据可见性配置 和元数据可见性故障排除。

示例

以下示例返回 master 数据库的 IsTruncLog 属性的设置。

 复制代码
USE master;
GO
SELECT DATABASEPROPERTY('master', 'IsTruncLog');

下面是结果集:

 复制代码
-------------------
1

查询数据库状态信息: ------------------------------Data file size---------------------------- if exists (select * from tempdb.sys.all_objects where name like '%#dbsize%') drop table #dbsize create table #dbsize (Dbname varchar(30),dbstatus varchar(20),Recovery_Model varchar(10) default ('NA'), file_Size_MB decimal(20,2)default (0),Space_Used_MB decimal(20,2)default (0),Free_Space_MB decimal(20,2) default (0)) go insert into #dbsize(Dbname,dbstatus,Recovery_Model,file_Size_MB,Space_Used_MB,Free_Space_MB) exec sp_msforeachdb 'use [?]; select DB_NAME() AS DbName, CONVERT(varchar(20),DatabasePropertyEx(''?'',''Status'')) , CONVERT(varchar(20),DatabasePropertyEx(''?'',''Recovery'')), sum(size)/128.0 AS File_Size_MB, sum(CAST(FILEPROPERTY(name, ''SpaceUsed'') AS INT))/128.0 as Space_Used_MB, SUM( size)/128.0 - sum(CAST(FILEPROPERTY(name,''SpaceUsed'') AS INT))/128.0 AS Free_Space_MB from sys.database_files where type=0 group by type' go -------------------log size-------------------------------------- if exists (select * from tempdb.sys.all_objects where name like '#logsize%') drop table #logsize create table #logsize (Dbname varchar(30), Log_File_Size_MB decimal(20,2)default (0),log_Space_Used_MB decimal(20,2)default (0),log_Free_Space_MB decimal(20,2)default (0)) go insert into #logsize(Dbname,Log_File_Size_MB,log_Space_Used_MB,log_Free_Space_MB) exec sp_msforeachdb 'use [?]; select DB_NAME() AS DbName, sum(size)/128.0 AS Log_File_Size_MB, sum(CAST(FILEPROPERTY(name, ''SpaceUsed'') AS INT))/128.0 as log_Space_Used_MB, SUM( size)/128.0 - sum(CAST(FILEPROPERTY(name,''SpaceUsed'') AS INT))/128.0 AS log_Free_Space_MB from sys.database_files where type=1 group by type' go --------------------------------database free size if exists (select * from tempdb.sys.all_objects where name like '%#dbfreesize%') drop table #dbfreesize create table #dbfreesize (name varchar(50), database_size varchar(50), Freespace varchar(50)default (0.00)) insert into #dbfreesize(name,database_size,Freespace) exec sp_msforeachdb 'use ?;SELECT database_name = db_name() ,database_size = ltrim(str((convert(DECIMAL(15, 2), dbsize) + convert(DECIMAL(15, 2), logsize)) * 8192 / 1048576, 15, 2) + ''MB'') ,''unallocated space'' = ltrim(str(( CASE WHEN dbsize >= reservedpages THEN (convert(DECIMAL(15, 2), dbsize) - convert(DECIMAL(15, 2), reservedpages)) * 8192 / 1048576 ELSE 0 END ), 15, 2) + '' MB'') FROM ( SELECT dbsize = sum(convert(BIGINT, CASE WHEN type = 0 THEN size ELSE 0 END)) ,logsize = sum(convert(BIGINT, CASE WHEN type 0 THEN size ELSE 0 END)) FROM sys.database_files ) AS files ,( 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 sys.partitions p INNER JOIN sys.allocation_units a ON p.partition_id = a.container_id LEFT JOIN sys.internal_tables it ON p.object_id = it.object_id ) AS partitions' ----------------------------------- if exists (select * from tempdb.sys.all_objects where name like '%#alldbstate%') drop table #alldbstate create table #alldbstate (dbname varchar(25), DBstatus varchar(25), R_model Varchar(20)) --select * from sys.master_files insert into #alldbstate (dbname,DBstatus,R_model) select name,CONVERT(varchar(20),DATABASEPROPERTYEX(name,'status')),recovery_model_desc from sys.databases --select * from #dbsize insert into #dbsize(Dbname,dbstatus,Recovery_Model) select dbname,dbstatus,R_model from #alldbstate where DBstatus 'online' insert into #logsize(Dbname) select dbname from #alldbstate where DBstatus 'online' insert into #dbfreesize(name) select dbname from #alldbstate where DBstatus 'online' select d.Dbname,d.dbstatus,d.Recovery_Model, (file_size_mb + log_file_size_mb) as DBsize, d.file_Size_MB,d.Space_Used_MB,d.Free_Space_MB, l.Log_File_Size_MB,log_Space_Used_MB,l.log_Free_Space_MB,fs.Freespace as DB_Freespace from #dbsize d join #logsize l on d.Dbname=l.Dbname join #dbfreesize fs on d.Dbname=fs.name order by Dbname
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值