SQL Server 运维常用sql语句(二)

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: SQL Server 运维常用sql语句(二)

查看当前用户查看当前用户

  1. select system_user

检查SQL Agent是否开启

  1. IF EXISTS (
  2. SELECT TOP 1 1
  3. FROM sys.sysprocesses
  4. WHERE program_name = 'SQLAgent - Generic Refresher'
  5. )
  6. SELECT 'Running'
  7. ELSE
  8. SELECT 'Not Running'

查看是否做了镜像

  1. select
  2.    a.database_id
  3.    ,a.name 数据库名称
  4.    ,case when b.mirroring_guid is null then '否' else '是' end 是否镜像
  5.    ,b.mirroring_partner_name 镜像服务器名称
  6. from
  7. [sys].[databases] a
  8. left join [sys].[database_mirroring] b on a.database_id=b.database_id

分离数据库

  1. USE master;
  2. EXEC sp_detach_db @dbname = 'test';#test指需要分离的数据库

附加数据库

  1. SELECT type_desc, name, physical_name from sys.database_files;#查看物理数据库文件的位置
  2. #使用带 FOR ATTACH 子句的 CREATE DATABASE 语句附加之前分离的test数据库
  3. CREATE DATABASE test  
  4.    ON (FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\test.mdf'),  
  5.    (FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\test_log.ldf')  
  6.    FOR ATTACH;

查看主从复制关系

  1. SELECT * FROM msdb.dbo.sysjobs
  2. SELECT
  3.    serverproperty('servername') AS ServerName,
  4.    CASE
  5.        WHEN serverproperty('servername') = '主服务器名称' THEN '主服务器'
  6.        ELSE '从服务器'
  7.    END AS ServerRole
  8. #也可以通过以下语句来查询
  9.    SELECT * FROM sys.objects WHERE name = 'MSreplication_options'

查看实例级别的信息

  1. select SERVERPROPERTY ('test')

查看实例级别的某个参数allow updates的配置

  1. select * from sys.configurations where name='allow updates'

查询当前数据库的所有架构范围的对象

  1. select * from sys.all_objects

查询当前数据库的所有对象

  1. select * from sys.sysobjects

在当前数据库下可以查询到所有数据库信息,包含是否on状态

  1. select * from sys.databases

查询所有数据库信息

  1. select * from sys.sysdatabases

查询当前数据库下所有正在SQL Server 实例上运行的进程的相关信息

  1. select * from sys.sysprocesses

监控日志空间

  1. DBCC SQLPERF (LOGSPACE)

查看数据库各种设置

  1. select name,State,user_access,is_read_only,recovery_model from sys.databases

查询当前数据库是否有会话

  1. select DB_NAME(dbid),* from sys.sysprocesses where dbid=db_id('test')

查询当前阻塞的所有请求

  1. SELECT session_Id,spid,ecid,DB_NAME (sp.dbid),nt_username,er.status,wait_type,
  2. [Individual Query] =SUBSTRING (qt.text,er.statement_start_offset / 2,
  3. ( CASE
  4. WHEN er.statement_end_offset = -1
  5. THEN
  6. LEN (CONVERT (NVARCHAR (MAX), qt.text)) * 2
  7. ELSE
  8. er.statement_end_offset
  9. END
  10. - er.statement_start_offset)
  11. / 2),
  12. qt.text,program_name,Hostname,nt_domain,start_time
  13. FROM sys.dm_exec_requests er
  14. INNER JOIN sys.sysprocesses sp ON er.session_id = sp.spid
  15. CROSS APPLY sys.dm_exec_sql_text (er.sql_handle) AS qt
  16. WHERE session_Id > 50 /* Ignore system spids.*/
  17. AND sp.blocked>0 AND session_Id NOT IN (@@SPID)

查看活动线程执行的sql语句,并生成批量杀掉的语句

  1. select 'KILL '+CAST(a.spid AS NVARCHAR(100)) AS KillCmd,REPLACE(hostname,' ','') as hostname ,replace(program_name,' ','') as program_name
  2. ,REPLACE(loginame, ' ', '') AS loginame, db_name(a.dbid) AS DBname,spid,blocked,waittime/1000 as waittime
  3. ,a.status,Replace(b.text,'''','''') as sqlmessage,cpu
  4. from sys.sysprocesses as a with(nolock)
  5. cross apply sys.dm_exec_sql_text(sql_handle) as b
  6. where a.status<>'sleeping' AND a.spid<>@@SPID

查看数据库的最近备份信息

  1. SELECT database_name,type,MAX(backup_finish_date) AS backup_finish_date FROM msdb.dbo.backupset GROUP BY database_name,type ORDER BY database_name,type
  2. 备注:D 表示全备份,i 表示差异备份,L 表示日志备份

查看备份进度

  1. SELECT DB_NAME(database_id) AS Exec_DB
  2. ,percent_complete
  3. ,CASE WHEN estimated_completion_time < 36000000
  4. THEN '0' ELSE '' END + RTRIM(estimated_completion_time/1000/3600)
  5. + ':' + RIGHT('0' + RTRIM((estimated_completion_time/1000)%3600/60), 2)
  6. + ':' + RIGHT('0' + RTRIM((estimated_completion_time/1000)%60), 2) AS [Time Remaining]
  7. ,b.text as tsql
  8. ,*
  9. FROM SYS.DM_EXEC_REQUESTS
  10. cross apply sys.dm_exec_sql_text(sql_handle) as b
  11. WHERE command LIKE 'Backup%' --and database_id=db_id('cardorder')
  12. --OR command LIKE 'RESTORE%'
  13. ORDER BY 2 DESC

查询always on状态是否正常

  1. select dc.database_name, d.synchronization_health_desc, d.synchronization_state_desc, d.database_state_desc from sys.dm_hadr_database_replica_states d join sys.availability_databases_cluster dc on d.group_database_id=dc.group_database_id and d.is_local=1

查看mirror镜像信息

  1. SELECT
  2. db_name(database_id),
  3. mirroring_state_desc,
  4. mirroring_role_desc,
  5. mirroring_partner_name,
  6. mirroring_partner_instance
  7. FROM sys.database_mirroring

查看每个数据库实例的数据量大小

  1. SELECT
  2. DB_NAME(db.database_id) DatabaseName,
  3. (CAST(mfrows.RowSize AS FLOAT)*8)/1024 RowSizeMB,
  4. (CAST(mflog.LogSize AS FLOAT)*8)/1024 LogSizeMB,
  5. (CAST(mfstream.StreamSize AS FLOAT)*8)/1024 StreamSizeMB,
  6. (CAST(mftext.TextIndexSize AS FLOAT)*8)/1024 TextIndexSizeMB
  7. FROM sys.databases db
  8. LEFT JOIN (SELECT database_id, SUM(size) RowSize FROM sys.master_files WHERE type = 0 GROUP BY database_id, type) mfrows ON mfrows.database_id = db.database_id
  9. LEFT JOIN (SELECT database_id, SUM(size) LogSize FROM sys.master_files WHERE type = 1 GROUP BY database_id, type) mflog ON mflog.database_id = db.database_id
  10. LEFT JOIN (SELECT database_id, SUM(size) StreamSize FROM sys.master_files WHERE type = 2 GROUP BY database_id, type) mfstream ON mfstream.database_id = db.database_id
  11. LEFT JOIN (SELECT database_id, SUM(size) TextIndexSize FROM sys.master_files WHERE type = 4 GROUP BY database_id, type) mftext ON mftext.database_id = db.database_id

查询总耗CPU最多的前3个SQL,且最近5天出现过

  1. SELECT TOP 3
  2. total_worker_time/1000 AS [总消耗CPU 时间(ms)],execution_count [运行次数],
  3. qs.total_worker_time/qs.execution_count/1000 AS [平均消耗CPU 时间(ms)],
  4. last_execution_time AS [最后一次执行时间],max_worker_time /1000 AS [最大执行时间(ms)],
  5. SUBSTRING(qt.text,qs.statement_start_offset/2+1,
  6. (CASE WHEN qs.statement_end_offset = -1
  7. THEN DATALENGTH(qt.text)
  8. ELSE qs.statement_end_offset END -qs.statement_start_offset)/2 + 1)
  9. AS [使用CPU的语法], qt.text [完整语法],
  10. qt.dbid, dbname=db_name(qt.dbid),
  11. qt.objectid,object_name(qt.objectid,qt.dbid) ObjectName
  12. FROM sys.dm_exec_query_stats qs WITH(nolock)
  13. CROSS apply sys.dm_exec_sql_text(qs.sql_handle) AS qt
  14. WHERE execution_count>1 and last_execution_time>dateadd(dd,-5,getdate())
  15. ORDER BY total_worker_time DESC

查看当前最耗资源的10个SQL及其spid

  1. SELECT TOP 10
  2. session_id,request_id,start_time AS '开始时间',status AS '状态',
  3. command AS '命令',d_sql.text AS 'sql语句', DB_NAME(database_id) AS '数据库名',
  4. blocking_session_id AS '正在阻塞其他会话的会话ID',
  5. wait_type AS '等待资源类型',wait_time AS '等待时间',wait_resource AS '等待的资源',
  6. reads AS '物理读次数',writes AS '写次数',logical_reads AS '逻辑读次数',
  7. row_count AS '返回结果行数'
  8. FROM sys.dm_exec_requests AS d_request
  9. CROSS APPLY
  10. sys.dm_exec_sql_text(d_request.sql_handle) AS d_sql
  11. WHERE session_id>50
  12. ORDER BY cpu_time DESC
  13. --前50session_id一般是系统后台进程,sys.dm_exec_requestsstatus显示为background

always on

查看集群各节点的信息,包含节点成员的名称,类型,状态,拥有的投票仲裁数

  1. SELECT * FROM  sys.dm_hadr_cluster_members;

查看集群各节点的信息,包含节点成员的名称,节点成员上的sql实例名称

  1. select * from sys.dm_hadr_instance_node_map

查看WSFC(windows server故障转移群集)的信息,包含集群名称,仲裁类型,仲裁状态

  1. SELECT * FROM SYS.dm_hadr_cluster;

查看AG名称

  1. select * from sys.dm_hadr_name_id_map
  2. 查看集群各节点的子网信息,包含节点成员的名称,子网段,子网掩码
  3. SELECT * FROM  sys.dm_hadr_cluster_networks;

查看侦听ip

  1. select * from sys.availability_group_listeners;

查看主从各节点的状态

复制

  1. select d.is_local,dc.database_name, d.synchronization_health_desc,
  2. d.synchronization_state_desc, d.database_state_desc
  3. from sys.dm_hadr_database_replica_states d
  4. join sys.availability_databases_cluster dc
  5. on d.group_database_id=dc.group_database_id;

查看辅助副本(传说中的从库)延迟多少M日志量

  1. select db_name(database_id),log_send_queue_size/1024 delay_M,*
  2. from sys.dm_hadr_database_replica_states where is_primary_replica=0;

查看DDL操作的记录

  1. select * from Sys.traces
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
29天前
|
SQL 运维 关系型数据库
MySQL 运维 SQL 备忘
MySQL 运维 SQL 备忘录
45 1
|
1月前
|
SQL 关系型数据库 MySQL
详解 pypika 模块:SQL 语句生成器,让你再也不用为拼接 SQL 语句而发愁
详解 pypika 模块:SQL 语句生成器,让你再也不用为拼接 SQL 语句而发愁
74 4
|
1月前
|
SQL 数据库
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
215 0
|
3月前
|
SQL XML 运维
SQL Server 运维常用sql语句(三)
SQL Server 运维常用sql语句(三)
25 1
|
3月前
|
Java 应用服务中间件 Maven
从零到英雄:一步步构建你的首个 JSF 应用程序,揭开 JavaServer Faces 的神秘面纱
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的 Java EE 标准,用于构建企业级 Web 应用。它提供了丰富的组件库和声明式页面描述语言 Facelets,便于开发者快速开发功能完善且易于维护的 Web 应用。本文将指导你从零开始构建一个简单的 JSF 应用,包括环境搭建、依赖配置、Managed Bean 编写及 Facelets 页面设计。
91 0
|
3月前
|
SQL 关系型数据库 MySQL
【超全整理】SQL日期与时间函数大汇总会:MySQL与SQL Server双轨对比教学,助你轻松搞定时间数据处理难题!
【8月更文挑战第31天】本文介绍了在不同SQL数据库系统(如MySQL、SQL Server、Oracle)中常用的日期与时间函数,包括DATE、NOW()、EXTRACT()、DATE_ADD()、TIMESTAMPDIFF()及日期格式化等,并提供了具体示例。通过对比这些函数在各系统中的使用方法,帮助开发者更高效地处理日期时间数据,满足多种应用场景需求。
348 0
|
3月前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
360 0
|
2月前
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
101 12
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
|
6天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
7天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。