SQL Server2005 发送邮件

     在以前的版本中,SQL Server通过Sql Mail来实现对电子邮件的收发等功能。在Sql Server2005中新增了数据库邮件功能,并且在今后的版本中将不再支持Sql Mail。原因在于SQL Mail使用外部电子邮件应用程序(例如 Microsoft Outlook)中的扩展 MAPI 客户端组件来发送和接收电子邮件。因此,若要使用 SQL Mail,必须在运行 SQL Server 的计算机上安装支持扩展 MAPI 的电子邮件应用程序。而数据库邮件则是一种通过 Microsoft SQL Server 2005 Database Engine 发送电子邮件的企业解决方案。通过使用数据库邮件,数据库应用程序可以向用户发送电子邮件。

       数据库邮件(Database Mail)设计为与 SMTP 服务器配合使用,具有可靠性,灵活性,安全性,兼容性。考虑到Sql Server2005是基于.Net Framework 2.0,而在后者中新增了System.Net.Mail命名空间,相信数据库邮件也是利用了其中的一些功能。接下来就如何启用和配置数据库邮件进行介绍。

       出于安全性的考虑,默认地是不开启数据库功能。启用数据库邮件功能有两种方式:使用SQL Server 外围应用配置器工具或数据库邮件配置向导显式启用数据库邮件。通过外围应用配置器工具启用的方式启动后,选择功能的外围应用配置器,然后启用数据库邮件存储过程。如下图:

http://s3.sinaimg.cn/orignal/3f2ef11806cdc1fc835c2

       配置数据库邮件是打开Sql Server Management Studio(Sqlwb.exe),然后在对象资源管理器中的实例下,打开【管理】,然后在【数据库邮件】上右键后点击【配置数据库邮件】,如下图:

http://s1.sinaimg.cn/orignal/3f2ef1184409951f91580

       在弹出【欢迎使用数据库邮件配置向导】对话框,在该对话框里单击【下一步】按钮。

http://s6.sinaimg.cn/orignal/3f2ef118440996731d8e5
       点击【下一步】后出现【新建配置文件】:

http://s2.sinaimg.cn/orignal/3f2ef1184409967558641
     
       然后点击【添加】:

http://s10.sinaimg.cn/orignal/3f2ef11844099677235e9
     
     点击【下一步】后管理配置文件安全性,将其设置为默认配置文件:

http://s10.sinaimg.cn/orignal/3f2ef11844099876a18f9
     
       然后点击【下一步】完成配置:

http://s3.sinaimg.cn/orignal/3f2ef11844099878c8272

http://s8.sinaimg.cn/orignal/3f2ef1184409987a72d97
     
http://s2.sinaimg.cn/orignal/3f2ef11806cdc272c9701

       这样就完成了数据库邮件的配置。然后可以在【数据库邮件】上右键后选择【发送测试电子邮件】:

http://s2.sinaimg.cn/orignal/3f2ef11844099bef116c1

       稍等片刻,如果配置正确,我们就可以收到这个测试邮件了。
     
http://s13.sinaimg.cn/orignal/3f2ef11844099bf066d5c

       我们可以通过在【数据库邮件】上右键选择【查看数据库邮件日志】查看日志:
     
http://s1.sinaimg.cn/orignal/3f2ef11844099bf21a0c0
       由于数据库邮件只是通过使用 Microsoft SMTP 服务器进行了测试,从我的测试拉看,好像有的SMTP邮件服务器似乎不能通过,原因不明。由于邮件服务器故障,无法将邮件发送给收件人。 ( 使用帐户 1 (2007-12-06T11:17:08) 发送邮件。 异常邮件: 无法将邮件发送到邮件服务器。 (不是本地用户;请尝试不同的路径。 服务器响应为: auth error. (è??¤óà??꧰ü))。  )

       如果出现: 由于邮件服务器故障,无法将邮件发送给收件人。 (使用帐户 1 (2007-12-06T10:08:32) 发送邮件。 异常邮件: 无法将邮件发送到邮件服务器。 (不允许使用邮箱名称。 服务器响应为: You are not authorized to send mail, authentication is required)。  )这样的错误应该是你的SMTP邮件服务器要求认证,而你没有提供正确的帐户密码或者是错误地选择了匿名身份认证(如果SMTP邮件服务器没启用匿名的话)。

       也可以通过:

       SELECT * FROM msdb.dbo.sysmail_allitems

       SELECT * FROM msdb.dbo.sysmail_event_log

       EXEC msdb.dbo.sp_send_dbmail
       @profile_name = 'DBMAIL',
       @recipients = 'demo@163.com',
       @body = 'The stored procedure finished successfully.',
       @subject = 'Automated Success Message' ;

       查看邮件发送情况或日志。


参考:

  • Sql Server 2005联机丛书
  • http://blog.sina.com.cn/s/blog_3f2ef11801000c2a.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值