开发者社区> 金澎> 正文

SQL Server脚本积累

简介: 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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
power designer pdm生成sql脚本和数据库以及逆向工程
正向工程:PDM--->sql or database 项目中我们经常需要根据PDM生成sql脚本,然后由sql脚本一起执行到数据库中,如果PDM中表比较多,我们一个个去建的话会很费时间,根据需要我们也可以直接将pdm生成到数据库中。 逆向工程:sql or database --->PDM 有时我们也需要根据sql脚本生成pdm图,或者是数据库的最新信息生成到PDM中
1516 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
27719 0
shell动态脚本和pl/sql动态脚本的比较
最近项目有一个需求,需要在多个数据库的schema上跑一些脚本。希望dba能够提供一个脚本,能够根据需求在环境中执行指定的脚本。 乍一听,没什么技术难点,为了更明白的说明问题,我举个例子。
709 0
SqlServer迁移基础 --生成所迁移数据库所有表的tablediff脚本
tablediff 实用工具用于比较两个非收敛表中的数据,它对于排除复制拓扑中的非收敛故障非常有用。
4252 0
使用SQLCMD在SQLServer执行多个脚本
原文: 使用SQLCMD在SQLServer执行多个脚本 概述:          作为DBA,经常要用开发人员提供的SQL脚本来更新正式数据库,但是一个比较合理的开发流程,当提交脚本给DBA执行的时候,可能已经有几百个sql文件,并且有执行顺序,如我现在工作的公司,十几个客户,每个客户一个库,但是数据库结构、存储过程、视图等都是一模一样,每次执行脚本(以下称为升级),如果有一百个脚本,那么就要按顺序执行过千次,这种工作量可不是一个人能承受得了的。
953 0
SQL Server定时自动抓取耗时SQL并归档数据脚本分享
原文:SQL Server定时自动抓取耗时SQL并归档数据脚本分享 SQL Server定时自动抓取耗时SQL并归档数据脚本分享 第一步建库 USE [master] GO CREATE DATABASE [MonitorElapsedHighSQL] GO 第二步创建sp_who3存储过程 -- http://sqlserverplanet.
1126 0
+关注
11
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载