SQL Server脚本积累

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: SQL Server脚本

1、查询存储过程创建时间和修改时间
select [name],create_date,modify_date FROM sys.all_objects where type_desc = N'SQL_STORED_PROCEDURE' and name = '存储过程名'

2、修改恢复模式
USE [master]
GO
ALTER DATABASE 数据库名 SET RECOVERY 恢复模式名 WITH NO_WAIT
GO

3、查询SQLzhixin执行超时时间
select CONVERT(varchar,value) as value from sys.configurations where name like '%remote query timeout%'

4、查看当前运行的SQL
SELECT [Spid] = session_id ,

    [Database] = DB_NAME(sp.dbid) ,
    [User] = nt_username ,
    [Status] = er.status ,
    [Wait] = wait_type ,
    [Individual Query] = SUBSTRING(qt.text,
                                       er.statement_start_offset / 2,
                                       ( CASE WHEN er.statement_end_offset = -1
                                              THEN LEN(CONVERT(NVARCHAR(MAX), qt.text))
                                                   * 2
                                              ELSE er.statement_end_offset
                                         END - er.statement_start_offset )
                                       / 2) ,
        [Parent Query] = qt.text ,
        Program = program_name ,
        hostname ,
        nt_domain ,
        start_time
FROM    sys.dm_exec_requests er
        INNER JOIN sys.sysprocesses sp ON er.session_id = sp.spid
        CROSS APPLY sys.dm_exec_sql_text(er.sql_handle) AS qt
WHERE   session_id > 50 
        AND session_id NOT IN ( @@SPID ) 

5、JOB历史记录查询
--适用官方SQL Server
SELECT msdb.dbo.agent_datetime(h.run_date, h.run_time) AS 'RunDateTime' ,

       h.run_date AS Run_Date ,   
       CAST(run_duration / 10000 AS VARCHAR(2)) + N'小时' + CAST(( run_duration - run_duration / 10000 * 10000 ) / 100 AS VARCHAR(2)) + N'分钟' + SUBSTRING(CAST(run_duration AS VARCHAR(10)),
       LEN(CAST(run_duration AS VARCHAR(10))) - 1, 2) + N'秒' AS run_duration2,    
       j.name AS Job_Name ,
       h.step_name AS Step_Name ,
       h.run_status ,
       h.message AS Message 

FROM msdb.dbo.sysjobhistory h
LEFT JOIN msdb.dbo.sysjobs j

       ON h.job_id = j.job_id

WHERE CONVERT(DATE,msdb.dbo.agent_datetime(h.run_date, h.run_time),121) = CONVERT(DATE,GETDATE())
AND h.step_id!=0
ORDER BY msdb.dbo.agent_datetime(h.run_date, h.run_time) DESC

--RDS不支持 msdb.dbo.agent_datetime,下面这个脚本代替,实现同样的效果,适用RDS For SQL Server
SELECT
convert(datetime,
left((cast(h.run_date as varchar)+cast(h.run_time as varchar)),4)+'-'

    +substring((cast(h.run_date as varchar)+cast(h.run_time as varchar)),5,2)
    +'-'+substring((cast(h.run_date as varchar)+cast(h.run_time as varchar)),7,2)
    +' '+substring((cast(h.run_date as varchar)+cast(h.run_time as varchar)),9,2)
    +':'+right((cast(h.run_date as varchar)+cast(h.run_time as varchar)),2)) AS RunDateTime,
       h.run_date AS Run_Date ,   
       CAST(run_duration / 10000 AS VARCHAR(2)) + N'小时' + CAST(( run_duration - run_duration / 10000 * 10000 ) / 100 AS VARCHAR(2)) + N'分钟' + SUBSTRING(CAST(run_duration AS VARCHAR(10)),
       LEN(CAST(run_duration AS VARCHAR(10))) - 1, 2) + N'秒' AS run_duration2,    
       j.name AS Job_Name ,
       h.step_name AS Step_Name ,
       h.run_status ,
       h.message AS Message 

FROM msdb.dbo.sysjobhistory h
LEFT JOIN msdb.dbo.sysjobs j

       ON h.job_id = j.job_id

WHERE CONVERT(varchar(10),CAST((cast( h.run_date as varchar))AS date),121) = CONVERT(DATE,GETDATE())
AND h.step_id!=0
ORDER BY RunDateTime DESC

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
|
2月前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
40 0
|
4月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
5月前
|
存储 SQL Go
全网最长的sql server巡检脚本分享(1000行)
全网最长的sql server巡检脚本分享(1000行)
100 1
|
5月前
|
SQL 存储 关系型数据库
bat脚本拼写SQL并写文件
【8月更文挑战第7天】bat脚本拼写SQL并写文件
62 5
|
6月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
163 13
|
6月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
6月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
87 6
|
5月前
|
SQL 存储 Go
SQL Server一键巡检脚本分享
SQL Server一键巡检脚本分享
83 0
|
5月前
|
SQL 监控 安全
在Linux中,如何检测和防止SQL注入和跨站脚本(XSS)攻击?
在Linux中,如何检测和防止SQL注入和跨站脚本(XSS)攻击?