SQL SERVER 2005邮件

       作为一个数据库管理员,如果每天的日常监控的结果可以使用一种方式能提醒到你的话,这样可以避免总是远程连接上SQL SERVER每隔一段时间就去运行个操作,然后再看结果。SQL SERVER 2005中自带的邮件功能可以实现这个需求哦。

今天介绍下如果通过邮件和计划任务来实现每隔1小时得到数据库缓存中平均操作最耗时的50个T-SQL语句。具体的操作分两步:

1.设置SQL SERVER的邮件功能

2.制定计划任务

我们先开始第一步操作:

1)登录数据库,在【对象资源管理器】里面按下图箭头操作

2)右键点击【数据库邮件】,选择【配置数据库邮件】,下一步操作后选择下图选项后继续下一步:

3)在出现的界面中执行下图中的操作

4)点击【添加】按钮后,再出现的对话中进行如下操作

5)下一步后,将SQLSERVEREMAIL前面的复选框选中后,下一步,完成。

这时数据库的邮件就配置好了。下面我们使用T-SQL语句来实现邮件的发送,此时用到一个存储过程msdb.dbo.sp_send_dbmail。该存储过程的具体用法见MSDN。

使用如下语句来查看缓存中平均操作时间前50的操作。

  
  
  
  
  1. Exec msdb.dbo.sp_send_dbmail  
  2.     @profile_name='SQLSERVEREMAIL1',    --使用的数据库邮件配置文件 
  3.     @recipients='[email protected]',    --收件人地址,多个收件人可用分号分隔 
  4.     @subject='每小时缓存中执行时间最长的50个语句',  --邮件主题  
  5.     @query='SELECT TOP 50 
  6. total_worker_time/execution_count/1000 AS [Avg CPU Time(ms)],deqs.execution_count, 
  7. (SELECT SUBSTRING(text,statement_start_offset/2+1,(CASE WHEN statement_end_offset = -1 then LEN(CONVERT(nvarchar(max), text)) * 2 ELSE statement_end_offset end -statement_start_offset)/2+1) FROM sys.dm_exec_sql_text(sql_handle)) AS query_text  
  8. FROM sys.dm_exec_query_stats deqs 
  9. ORDER BY [Avg CPU Time(ms)] DESC',  --具体的查询T-SQL 
  10. @attach_query_result_as_file = 1,   --查询结果以附件形式发送 
  11. @query_no_truncate = 1  --不截断长字段值 

将上面的T-SQL做成计划任务,并设置成每小时执行一次。

这样每小时邮箱里面就能收到需要的信息了。

你可能感兴趣的:(sql,数据库,server,邮件,休闲)