2024-11-04 产品展示 199
图片
一、基础命令查看当前数据库的版本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_nameFROM sys.database_permissions pJOIN sys.database_principals u ON p.grantee_principal_id = u.principal_idWHERE 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 = 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
and g.name = 'sysadmin'
order by 1, 2
go
查询当前用户所有用户表查看所有的数据库select name from sysobjects where xtype='u' order by name
Select Name FROM Master..SysDatabases orDER BY Name
查看服务器角色相关信息查看数据库角色相关信息SP_HELPSRVROLE
SP_HELPSRVROLEMEMBER 服务器角色
SP_HELPSRVROLE 服务器角色
SP_HELPROLE
SP_HELPROLEMEMBER 数据库角色
SP_HELPROLE 数据库角色
查看用户相关信息查看上次启动以来尝试的连接数SP_HELPUSER
SP_HELPUSER 数据库用户名
select &connections //返回 SQL Server 自上次启动以来尝试的连接数,无论连接是成功还是失败
当前实例允许同时进行的最大用户连接数查询当前最大的连接数select &max_connections
//返回 SQL Server 实例允许同时进行的最大用户连接数。返回的数值不一定是当前配置的数值
SELECT value_in_use
FROM sys.configurations c
WHERE c.name = 'user connections'; #0表示无限制
设置修改连接数查询当前会话超时时间exec sp_configure 'show advanced options', 1
RECONFIGURE WITH OVERRIDE
exec sp_configure 'user connections', 300
RECONFIGURE WITH OVERRIDE
select &lock_timeout //返回当前会话的当前锁定超时设置(毫秒)。
查询每个用户的连接数查看当前活动的实例select loginame,count(1) as Nums
from sys.sysprocesses
group by loginame
order by 2 desc
select spid,ecid,status,loginame,hostname,cmd,request_id
from sys.sysprocesses where loginame='' and hostname=''
SELECT CURRENT_USER AS [Current User], SESSION_USER AS [Session User];
查看当前活动进程查看所有数据库的大小SELECT * FROM sys.dm_exec_requests;
SELECT
DB_NAME(database_id) AS DatabaseName,
SUM(size/128.0) AS SizeInMB,
SUM(size/128.0)/1024 AS SizeInGB
FROM
sys.master_files
GROUP BY
database_id
ORDER BY
SizeInMB DESC;
查看某个数据库的大小查看当前数据库的日志大小SELECT sys.databases.name AS [Database Name],
CAST(SUM(size * 8 / 1024.0) AS DECIMAL(10,2)) AS [Size (MB)]
FROM sys.master_files
INNER JOIN sys.databases ON sys.master_files.database_id = sys.databases.database_id
WHERE sys.databases.name = 'master'
GROUP BY sys.databases.name;
#也可以用EXEC sp_spaceused @updateusage = N'TRUE';
SELECT sys.databases.name AS [Database Name],
CAST(size * 8 / 1024.0 AS DECIMAL(10,2)) AS [Log File Size (MB)]
FROM sys.master_files
INNER JOIN sys.databases ON sys.master_files.database_id = sys.databases.database_id
WHERE sys.databases.name = 'master'
AND sys.master_files.type = 1;
查询当前数据库的表和视图查询表结构信息SELECT TABLE_NAME AS [Table/View Name], TABLE_TYPE AS [Type]
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE IN ('BASE TABLE', 'VIEW');
sp_help 'test';
二、运维小技巧一次性清除数据库所有表的数据(高危操作,谨慎)数据备份与恢复备份CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'
EXEC sp_MSForEachTable 'DELETE FROM ?'
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'
GO
BACKUP DATABASE test TO DISK = 'C:\backup\MyDatabase.bak';
恢复完整数据库备份RESTORE DATABASE MyDatabase FROM DISK = 'C:\backup\MyDatabase.bak';
BACKUP DATABASE test
TO DISK = 'C:\Backup\MyDatabase.bak'
WITH FORMAT, MEDIANAME = 'MyDatabase_Full', NAME = 'Full Backup';
差异备份事务日志备份BACKUP DATABASE test
TO DISK = 'C:\Backup\MyDatabase_diff.bak'
WITH DIFFERENTIAL, FORMAT, MEDIANAME = 'MyDatabase_Diff', NAME = 'Differential Backup';
BACKUP LOG test
TO DISK = 'C:\Backup\MyDatabase_log.trn'
WITH NOFORMAT, NOINIT, NAME = N'MyDatabase_LogBackup', SKIP, NOREWIND, NOUNLOAD, STATS = 10;
还原数据库创建账户及数据库用户RESTORE DATABASE test
FROM DISK = 'C:\Backup\MyDatabase.bak'
WITH FILE = 1, NOUNLOAD, REPLACE, STATS = 5;
#创建账户
CREATE LOGIN test WITH PASSWORD = '123123';
#创建数据库用户并映射到登录名
CREATE USER test FOR LOGIN test;
ALTER ROLE db_datareader ADD MEMBER test; -- 给予读权限
ALTER ROLE db_datawriter ADD MEMBER test; -- 给予写权限
SQL优化相关、执行时间SELECT creation_time N'语句编译时间'
,last_execution_time N'上次执行时间'
,total_physical_reads N'物理读取总次数'
,total_logical_reads/execution_count N'每次逻辑读次数'
,total_logical_reads N'逻辑读取总次数'
,total_logical_writes N'逻辑写入总次数'
,execution_count N'执行次数'
,total_worker_time/1000 N'所用的CPU总时间ms'
,total_elapsed_time/1000 N'总花费时间ms'
,(total_elapsed_time / execution_count)/1000 N'平均时间ms'
,SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,
((CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset END
- qs.statement_start_offset)/2) + 1) N'执行语句'
FROM sys.dm_exec_query_stats AS qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) st
WHERE SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,
((CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset END
- qs.statement_start_offset)/2) + 1) NOT LIKE '
下一篇:没有了