开发者社区> 长征6号> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

数据库邮件

简介:
+关注继续查看

SQL Server数据库邮件使用 SMTP 服务器转发邮件,允许用户配置数据库邮件,并通过存储过程 msdb.dbo.sp_send_dbmail 向特定的用户发送邮件,邮件的格式可以是文本、Excel、或HTML。数据库邮件的最大用处是向数据库运维人员及时发送异常信息,当数据库出现异常时,数据库系统可以在第一时间发送邮件通知数据库运维人员,这样便于尽快排除数据库运行的异常情况,保证数据库能够正常、持续地提供服务。 

一,配置数据库邮件

配置数据库邮件时,主要配置两个对象:Account 和 Profile,数据库账户(Account)包含SQL Server用于把邮件发送给SMTP 服务器的信息,包含外发(outgoing)的邮件地址,显示名(Display Name)以及使用SMTP服务器地址;每一个account包含一个SMTP 服务器。数据库邮件配置(Profile)是账户(Account)的有序集合,存储过程 msdb.dbo.sp_send_dbmail 或SQL Server Agent 使用Profile发送邮件,而不是直接使用Account。Profile提供邮件发送服务的自动故障转移(failover),由于一个Profile包含多个Account,当第一个Account出现故障时,Profile自动使用后续的Account发送邮件,实现邮件发送的自动故障转移。当SMTP服务器变更时,DBA只需要修改Account,而不需要修改Profile,使得编程更加灵活和可靠。

下面的示例图展示数据库邮件的配置:3个Account,2个Profile,每个Profile都包含2个Account,

1,打开配置数据库邮件的向导

在SSMS的Management目录中,右击“Database Mail”弹出快捷菜单,点击“Configure Database Mail”,打开数据库邮件配置向导 “Database Mail Configuration Wizard”,在向导界面上,选择“Set up Database Mail by performing the following tasks”选项,点击“Next”按钮,开始配置数据库邮件:

2,创建数据库邮件配置(Profile)

在发送数据库邮件之前,必须创建数据库邮件的配置(Profile),在配置中指定:邮件服务器(SMTP Server)的账户,一个数据库邮件配置可以包含多个SMTP 账户,点击“Add”按钮,添加SMTP Account:

3,配置SMTP账户

配置新添加的SMTP Account,配置数据库邮件的发送地址(E-mail Address)及其显示名称(Display Name),邮件服务器的地址(在Server Name中填写邮件服务器的URL,在Port Number中填写端口号),和身份验证(SMTP Authentication)信息:

在配置Account时,有三种SMTP验证方式,分别是Windows域账户验证、基本验证(用户名和密码)、匿名验证,大多数STMP服务器都需要账户登陆,很少有匿名验证方式。

4,设置默认的Profile

如果设置了默认的Profile,执行msdb.dbo.sp_send_dbmail 时不需要@profile_name显式指定配置名称:

5,发送测试邮件

数据库邮件(Database Mail)自带有"Send Test E-Mail"和“View Database Mail Log”的功能,用来查看Database mail的发送情况。

 二,使用TSQL语句发送mail

1,使用 msdb.dbo.sp_send_dbmail 发送mail,由于设置了default profile,所以不需要显示使用@Profile_Name来指定Profile。

EXEC msdb.dbo.sp_send_dbmail
    @recipients='xxx@domainname.com'
    ,@subject='Test email subject'
    ,@body='test email body'
    --,@profile_name='default'

使用msdb.dbo.sp_send_dbmail也能发送HTML格式的mail,需要在参数@body_format指定格式。
[ @body_format= ] 'body_format'

默认值是Text,表示发送的是邮件正文是text格式;HTML格式,可以使用HTML 标签

2,发送text格式的邮件

复制代码
EXEC msdb.dbo.sp_send_dbmail
    @recipients='xxx@domainname.com'
    ,@subject='Test email subject'
    ,@body='test email body'
    --,@profile_name='default_ProfileName'
    --,@body_format='text'
复制代码

@Body_Format 参数的默认值是Text

3,发送Html格式的mail

复制代码
declare @htmlbody varchar(max)
set @htmlbody='<table>
<tr>
    <td>first row</td>
</tr>
<tr>
    <td>second row</td>
</tr>
</table>'

EXEC msdb.dbo.sp_send_dbmail
    @recipients='xxx@domainname.com'
    ,@subject='Test email subject'
    ,@body=@htmlbody
    --,@profile_name='default_ProfileName'
    ,@body_format='Html'
复制代码

4,将查询结果作为mail的body

存储过程 msdb.dbo.sp_send_dbmail 可以执行一个select 查询子句,并将查询结果作为一个附件发送出去。

复制代码
EXEC msdb.dbo.sp_send_dbmail
    @recipients='xxx@domainname.com'
    ,@subject='Test email subject'
    --,@profile_name='default_ProfileName'
    --,@body_format='text'
    ,@query='select * from db_study.dbo.test'
    ,@attach_query_result_as_file = 1
复制代码

 

参考文档:

sp_send_dbmail (Transact-SQL)

作者悦光阴
本文版权归作者和博客园所有,欢迎转载,但未经作者同意,必须保留此段声明,且在文章页面醒目位置显示原文连接,否则保留追究法律责任的权利。

本文转自悦光阴博客园博客,原文链接:http://www.cnblogs.com/ljhdo/p/4552683.html,如需转载请自行联系原作者

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

相关文章
数据工厂15:数据库组件设计
数据工厂15:数据库组件设计
22 0
数据库范式
最近在开发新系统,理解业务,开始设计数据表结构; 寻找实体,确定实体间的关系及关系属性 梳理业务功能接口逻辑,其实也就是这个功能操作了哪张表的哪个字段 没有传说中的面向对象分析,DDD实践,流行的微服务玩法 也许,好久没有从零开发系统,很久没有亲手新建数据库表 沉默十秒钟,感觉像回到了学校,做个类似留言板,BBS类的学生系统;不是鄙视学生时代,而是有些恍惚 多年的工作经验,恍如做了个梦,现在设计的表结构与一名实习生有什么区别呢?
16 0
关系型数据库,第一!
云数据库占比持续增长
617 0
数据库
●数据库 OrmLite (JDBC和Android的轻量级ORM java包) Sugar (用超级简单的方法处理Android数据库) GreenDAO (一种轻快地将对象映射到SQLite数据库的ORM解决方案,使用的App有:薄荷,京...
856 0
裁切数据库
以前使用了GP工具来遍历数据库中的要素层,实现裁切。   现在尝试用Python,实现起来也比较方便,速度比写一个小的应用程序快得多   # -------------------------------------------------------------------------...
783 0
数据库设计
数据库设计 ER模型 Entity-Relationship,实体-关系模型。该模型的图形化表示就是ER图。 1.用矩形表示实体。 2.用椭圆表示实体属性。 3.用零星表示是体检关系。 例一:有一个简单的数据库系统,实体有班级、学生、课程。 一个班有若干个学生,一个学生只能属于一个班。 一个学生可以选修多门课,一门课有若干学生选修。 将ER图转换为关系数据模型 1.
1314 0
缓存数据库
memcache ehcache
430 0
+关注
1222
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载