一、            SQL Server发邮件原理和组件介绍:

数据库邮件有4个组件:配置文件、邮件处理组件、可执行文件以及“日志记录和审核组件”。

l  配置组件包括:

1)数据库邮件帐户包含诸如SMTP服务器名、身份验证类型和电子邮件地址等。

2)数据库邮件配置文件是数据库邮件帐户的集合。

l  邮件处理组件

要的数据库邮件组件就是刚才所说的数据库邮件主机数据库,默认是msdb。

l  数据库邮件可执行文件

数据库邮件使用一个外部可执行文件来处理邮件,降低了对SQL Server的影响。当有邮件要处理时,数据库邮件使用Service Broker激活外部程序(DataMail90.exe)发送邮件。

l  日志记录和审核组件

可以通过数据库邮件日志或查询sysmail_log系统视图来查看相关日志记录。

跟我们发送邮件一样,需要用户名和密码通过 SMTP(Simple Message Transfer Protocol) 去连接邮件服务器。我们想让SQL Server 来发送邮件,首先要告诉它用户名称,密码, 服务器地址,网络传送协议,邮件服务器的端口。。。等信息

二、            启用 SQL Server 2005 邮件功能

方法1:打开Sql Server外围应用配置器:

点击【功能外围应用配置】,在打开的页面中选择“数据库邮件”,选中“启用数据库邮件存储过程”

方法2:执行启用语句

use master
go

exec sp_configure 'show advanced options',1
go

reconfigure
go

exec sp_configure 'Database mail XPs',1
go

reconfigure
go

三、            启用数据库邮件主机数据库上的service broker

默认的数据库主机数据库是msdb,其service broker默认是启用的。您可以通过如下脚本来查看msdb是否启用了Service Broker:

SELECT is_broker_enabled FROM sys.databases WHERE name = 'msdb'

如果未启用,则返回“0”,如果启用,则返回1.你可以通过下面脚本来启用Service Broker:

ALTER DATABASE msdb SET ENABLE_BROKER

四、            配置数据库邮件

1)打开SSMS(SQL Server Management Studio),在对象浏览器中依次展开服务器、管理节点,在数据库邮件上点击右键,如图:

2)选择“配置数据库邮件”,将出现“数据库邮件配置向导”对话框。如图:

3)点击“下一步”,如果数据库邮件尚未启动,则弹出一个对话框,询问是否启用数据库邮件,选择“是”。

4)在“配置文件名”文本框中输入“worklogmial”,并单击“添加”以加入一个SMTP帐户。

5)在“新建数据库邮件帐户”对话框中,输入相关信息,确定。

6)点击下一步,在“管理配置文件安全性”页面上将“worklogmial”配置为公共配置文件,并单击下一步。

7)这时将出现“配置参数”页面,我们保持默认,单击下一步,再单击完成。

五、            发送测试邮件

1)再次右键对象浏览器中的“数据库邮件”节点,选择“发送测试电子邮件”,出现如下:

2)在数据配置文件的下拉框中选择我们刚才创建的“worklogmail”,填写收件人地址(如:jsyhello@gmail.com),点击“发送……”出现下图:(注意:发送电子邮件后面的数字"16"是测试邮件的ID,可以通过此唯一ID在日志中查询该邮件的状态。)

或者您可以通过如下脚本来发送一封测试邮件:

exec msdb.dbo.sp_send_dbmail

@profile_name=' worklogmail ',

@recipients='jsyhello@gmail.com',

@body='这是一封测试邮件',

@subject='测试'

六、            常见问题

1)ExternalMailQueue 接收到无效的 XML 消息格式。conversation_handle……

解决:至少为SQL Server安装SP1

2)由于邮件服务器故障,无法将邮件发送给收件人。 (使用帐户 1 (2007-12-06T10:08:32) 发送邮件。 异常邮件: 无法将邮件发送到邮件服务器。 (不允许使用邮箱名称。 服务器响应为: You are not authorized to send mail, authentication is required)。

解决:你的SMTP邮件服务器要求认证,而你没有提供正确的帐户密码或者是错误地选择了匿名身份认证。

3)使用帐户 1 (2007-12-06T11:17:08) 发送邮件。 异常邮件: 无法将邮件发送到邮件服务器。 (不是本地用户;请尝试不同的路径。服务器响应为: auth error.)。

解决:部分免费的公共邮箱的SMTP服务器不允许此项服务,请选择其他的SMTP。

七、            建立发送邮件的存储过程

--发送邮件模板存储过程

Create PROCEDURE [dbo].[MyMail]

@mailto varchar(max),

@mailsubject nvarchar(255),

@mailbody nvarchar(max)

AS

BEGIN

set @mailbody=replace(replace(@mailbody,'&lt;','<'),'&gt;','>')

+N'<br/>谢谢!<br/>祝您工作愉快!<br/>发件人:研发管理平台'

exec msdb.dbo.sp_send_dbmail

@profile_name = 'worklogmail',

@recipients = @mailto,

@subject = @mailsubject,

@body = @mailbody,

@body_format = 'HTML'

END

--日志提醒存储过程

Create proc [dbo].[MailUnWirte]

@days int=2

as

if EXISTS(select * from WorkWeek where datediff(day,WorkDay,getdate())=0 and Iflag=1)

begin

declare @calcDate datetime

select @calcDate=max(workday) from WorkWeek where datediff(day,WorkDay,getdate())>@days and Iflag=1

declare @username varchar(50)

declare @mailto varchar(max)

declare @depid varchar(20)

declare @mailbody nvarchar(max)

declare mailto cursor for

select S_User.Name,S_User.EMail,S_user.DepID

from S_User

inner join s_UserTransfer ut on ut.userid=S_User.id and ut.StartDate<=@calcDate

left join ProjectWorkLog l on l.EffortState=1 and S_User.id=l.worker and l.workday<=@calcDate

where S_User.Iflag='1' and S_User.IsEffort=1

group by S_User.Name,S_User.EMail,S_user.DepID

having isnull(sum(l.Effort),0)<8

  • open mailto

fetch next from mailto into @username,@mailto,@depid

while @@fetch_status=0

begin

set @mailbody=@username+'您好:<br/>&nbsp;&nbsp;&nbsp;&nbsp;您截至到'+convert(varchar(10),@calcDate,20)+',尚有工作日志未填写完毕,请尽快填写'

exec MyMail @mailto,N'日志未填写提醒',@mailbody

select @mailto=isnull(email,'') from s_user inner join s_dep on s_dep.Manager=s_user.id where s_dep.id=depid

if @mailto!=''

begin

set @mailbody='您好:<br/>&nbsp;&nbsp;&nbsp;&nbsp;'+@username+'截至到'+convert(varchar(10),@calcDate,20)+',尚有工作日志未填写完毕,请督促其按时填写'

exec MyMail @mailto,N'日志未填写提醒',@mailbody

end

fetch next from mailto into @username,@mailto,@depid

end

close mailto

deallocate mailto

end

八、            配置计划任务

1、新建作业

2、新建作业-常规:

步骤:常规设置完成,点击【步骤】选项,点击【新建】按钮进入

点击【确认】返回,可以看到步骤中增加了一条。

计划:步骤设置完成,点击【计划】选项,点击【新建】按钮进入

点击【确认】返回。可以看到计划中增加了一条。

其它选项可以不设置。

点击【确认】完成计划任务的添加。

在 SQL Server 2005 中配置数据库邮件的更多相关文章

  1. SQL Server 2008 /SQL Server 2008 R2 配置数据库邮件

    原文:SQL Server 2008 /SQL Server 2008 R2 配置数据库邮件 从2005开始,就引入了"数据库邮件"功能.并且取代SQLMail.原有SQLMail ...

  2. 在SQL SERVER 2005中还原数据库时出现错误:system.data.sqlclient.sqlerror 媒体集有 2 个媒体簇 但只提供了 1 个。必须提供所有成员。 (microsoft.sqlserver.smo)

    问题:在SQL SERVER 2005中还原数据库时出现错误:system.data.sqlclient.sqlerror 媒体集有 2 个媒体簇 但只提供了 1 个.必须提供所有成员. (micro ...

  3. SQL Server 2005中设置Reporting Services发布web报表的匿名访问

    原文:SQL Server 2005中设置Reporting Services发布web报表的匿名访问 一位朋友提出个问题:集成到SQL Server 2005中的Reporting Services ...

  4. SQL Server 2005中更改sa的用户名和密码

    修改数据库SA账号名称的代码如下:  代码如下: Alter LOGIN sa DISABLE Alter LOGIN sa WITH NAME = [systemAccount] "sys ...

  5. SQL Server 2005 中实现通用的异步触发器架构

    在SQL Server 2005中,通过新增的Service Broker可以实现异步触发器的处理功能.本文提供一种使用Service Broker实现的通用异步触发器方法. 在本方法中,通过Serv ...

  6. 实战SQL Server 2005镜像配置全过程

    SQL Server 2005镜像配置基本概念 我理解的SQL Server 2005镜像配置实际上就是由三个服务器(也可以是同一服务器的三个 SQL 实例)组成的一个保证数据的环境,分别是:主服务器 ...

  7. SQL Server 2005 中实现通用的异步触发器架构 (转)

    在SQL Server 2005中,通过新增的Service Broker可以实现异步触发器的处理功能.本文提供一种使用Service Broker实现的通用异步触发器方法. 在本方法中,通过Serv ...

  8. SQL Server 2005 中的分区表和索引

    SQL Server 2005 中的分区表和索引 SQL Server 2005          69(共 83)对本文的评价是有帮助 - 评价此主题   发布日期 : 3/24/2005 | 更新 ...

  9. SQL SERVER 2005中同义词实例

    From : http://www.cnblogs.com/jackyrong/archive/2006/11/15/561287.html 在SQL SERVER 2005中,终于出现了同义词了,大 ...

随机推荐

  1. 仿微博的JQuery日历控件

    实现原理主要是处理table,生成tr td,其中最重要的是如何找出每月第一天是星期几,然后就能对应出这个月的余下天数. 日历控件网上一搜一大把,但是我觉得自己写一遍还是有好处的.代码可以查看本页源代 ...

  2. 哲学家问题(java)的三个解法

    //加synchronize进行同步 //释放资源又很快获得自身的资源,这样不妥,吃完的话休息100ms //每个人先申请编号小的筷子 public class Philosopher impleme ...

  3. sql 事务的四种隔离级别

    在 SQL 标准中定义了四种隔离级别,每一种级别都规定了一个事务中所做的修改,哪些在事务内和事务间是可见的,哪些是不可见的.较低级别的隔离通常可以执行更高的并发,系统的开销也更低. read unco ...

  4. 01 C++ 多线程入门实例

    1.可复用的完整实例 #include <iostream> #include <thread> #include <mutex> using namespace ...

  5. Docker网络 Weave

    当容器分布在多个不同的主机上时,这些容器之间的相互通信变得复杂起来.容器在不同主机之间都使用的是自己的私有IP地址,不同主机的容器之间进行通讯需要将主机的端口映射到容器的端口上,而且IP地址需要使用主 ...

  6. python的tuple()元组数据类型的使用方法以及案例

    一.元组的概念介绍 1.元组是列表的二次加工 列表可以被修改 列表的类型 list li = [1,2,3,4,5,6] 2.元组的元素不可被修改,不能被增加或者删除,(只是针对元组的一级元素是不可以 ...

  7. Ansible lineinfile模块详解

    目录 简介 修改匹配行 在匹配行前或后添加内容 在匹配行前添加 在匹配行后添加 修改文件内容及权限 删除一行内容 文件存在则添加一行内容 如果有匹配的行则修改该行,如果不匹配则添加 参数backref ...

  8. Ansible10:Playbook的角色及包含

    目录 说明 一.Playbook的包含 1.tasks包含 2.handlers包含 3.混合包含 二.角色(roles) 1.创建role 2.引用roles 3.pre_tasks和post_ta ...

  9. numpy/arrayobject.h”: No such file or directory

    import numpyimport pyximportpyximport.install(setup_args={"script_args":["--compiler= ...

  10. jdk与jdt

    jdk是java的开发环境 ,程序的编译.运行都需要jdk.一个java开发平台,jdk少不了,而编辑器 可以多种多样,除了 eclipse中的JDT,还有独立的jcreate ,或者用记事本以其他加 ...