一、基础命令
查看当前数据库的版本
-
SELECT @@VERSION;
查看服务器部分特殊信息
-
select SERVERPROPERTY(N'edition') as Edition --数据版本,如企业版、开发版等
-
,SERVERPROPERTY(N'collation') as Collation --数据库字符集
-
,SERVERPROPERTY(N'servername') as ServerName --服务名
-
,@@VERSION as Version --数据库版本号
-
,@@LANGUAGE AS Language --数据库使用的语言,如us_english等
获取数据库当前时间
-
SELECT GETDATE() AS CurrentDateTime;
查看数据库启动的参数
-
sp_configure
查看所有数据库用户登录信息
-
sp_helplogins
查看数据库启动时间(最近一次)
-
select convert(varchar(30),login_time,120) from master..sysprocesses where spid=1
查看有多少个端口
-
SELECT * FROM sys.dm_tcp_listener_states;
查看当前的连接数
-
SELECT COUNT(*) AS [Connection Count] FROM sys.dm_exec_connections;
查看各个磁盘分区的剩余空间
-
Exec master.dbo.xp_fixeddrives
查看数据库的磁盘使用情况
-
Exec sp_spaceused
查看数据库服务器各数据库日志文件的大小及利用率
-
DBCC SQLPERF(LOGSPACE)
查看当前占用 cpu 资源最高的会话和其中执行的语句
-
select spid,cmd,cpu,physical_io,memusage,
-
(select top 1 [text] from ::fn_get_sql(sql_handle)) sql_text
-
from master..sysprocesses order by cpu desc,physical_io desc
查看缓存中重用次数少,占用内存大的查询语句(当前缓存中未释放的)
-
SELECT TOP 100 usecounts, objtype, p.size_in_bytes,[sql].[text]
-
FROM sys.dm_exec_cached_plans p OUTER APPLY sys.dm_exec_sql_text (p.plan_handle) sql
-
ORDER BY usecounts,p.size_in_bytes desc
看BUFFER POOL中,都缓存了哪些表(当前数据库)的数据
-
select OBJECT_NAME(object_id) 表名,COUNT(*) 页数,COUNT(*)*8/1024.0 Mb
-
from sys.dm_os_buffer_descriptors a,sys.allocation_units b,sys.partitions c
-
where a.allocation_unit_id=b.allocation_unit_id
-
and b.container_id=c.hobt_id
-
and database_id=DB_ID()
-
group by OBJECT_NAME(object_id)
-
order by 2 desc
查看用户的权限
-
EXEC sp_helprotect;
查看当前数据库内存使用情况
-
select * from sys.dm_os_process_memory
查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量
-
-- 查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量
-
-- 从这些信息可以看出,系统经常要访问的都是哪些表,有多大?
-
select p.object_id, object_name=object_name(p.object_id), p.index_id, buffer_pages=count(*)
-
from sys.allocation_units a,
-
sys.dm_os_buffer_descriptors b,
-
sys.partitions p
-
where a.allocation_unit_id=b.allocation_unit_id
-
and a.container_id=p.hobt_id
-
and b.database_id=db_id()
-
group by p.object_id,p.index_id
-
order by buffer_pages desc
查询缓存中具体的执行计划,及对应的SQL
-
-- 查询缓存中具体的执行计划,及对应的SQL
-
-- 将此结果按照数据表或SQL进行统计,可以作为基线,调整索引时考虑
-
-- 查询结果会很大,注意将结果集输出到表或文件中
-
SELECT usecounts ,
-
refcounts ,
-
size_in_bytes ,
-
cacheobjtype ,
-
objtype ,
-
TEXT
-
FROM sys.dm_exec_cached_plans cp
-
CROSS APPLY sys.dm_exec_sql_text(plan_handle)
-
ORDER BY objtype DESC ;
-
GO
查看具体某个用户的权限
SELECT p.class_desc, OBJECT_NAME(p.major_id) AS object_name, p.permission_name, p.state_desc, u.name AS user_name
FROM sys.database_permissions p
JOIN sys.database_principals u ON p.grantee_principal_id = u.principal_id
WHERE u.name = ‘test’
查看注册时的实例名
-
SELECT * FROM sys.servers;
查询用户角色
-
select SrvRole = g.name, MemberName = u.name, MemberSID = u.sid
-
from sys.server_principals u, sys.server_principals g, sys.server_role_members m
-
where g.principal_id = m.role_principal_id
-
and u.principal_id = m.member_principal_id
-
order by 1, 2
-
go
看服务器角色
-
select 用户名 = u.name,管理员权限 = g.name,是否在用 = u.is_disabled,MemberSID