SQL Server 使用触发器(trigger)发送电子邮件

sql 使用系统存储过程 sp_send_dbmail 发送电子邮件语法:

sp_send_dbmail [ [ @profile_name = ] 'profile_name' ]
  [ , [ @recipients = ] 'recipients [ ; ...n ]' ]
  [ , [ @copy_recipients = ] 'copy_recipient [ ; ...n ]' ]
  [ , [ @blind_copy_recipients = ] 'blind_copy_recipient [ ; ...n ]' ]
  [ , [ @subject = ] 'subject' ]  
  [ , [ @body = ] 'body' ]  
  [ , [ @body_format = ] 'body_format' ]
  [ , [ @importance = ] 'importance' ]
  [ , [ @sensitivity = ] 'sensitivity' ]
  [ , [ @file_attachments = ] 'attachment [ ; ...n ]' ]
  [ , [ @query = ] 'query' ]
  [ , [ @execute_query_database = ] 'execute_query_database' ]
  [ , [ @attach_query_result_as_file = ] attach_query_result_as_file ]
  [ , [ @query_attachment_filename = ] query_attachment_filename ]
  [ , [ @query_result_header = ] query_result_header ]
  [ , [ @query_result_width = ] query_result_width ]
  [ , [ @query_result_separator = ] 'query_result_separator' ]
  [ , [ @exclude_query_output = ] exclude_query_output ]
  [ , [ @append_query_error = ] append_query_error ]
  [ , [ @query_no_truncate = ] query_no_truncate ]
  [ , [ @mailitem_id = ] mailitem_id ] [ OUTPUT ]

参数参考地址:https://docs.microsoft.com/en-us/sql/relational-databases/system-stored-procedures/sp-send-dbmail-transact-sql

下面开始配置 sql 发送电子邮件:

步骤一:

-- 启用 sql server 邮件的功能
exec sp_configure 'show advanced options',1
go
reconfigure;
go

exec sp_configure 'Database Mail XPs',1
go
reconfigure;
go

如果上面的语句执行失败,也可以使用下面的语句。

-- 启用 sql server 邮件的功能
exec sp_configure 'show advanced options', 1
go
reconfigure with override
go

exec sp_configure 'Database Mail XPs', 1
go
reconfigure with override
go

使用下面的语句查看数据库邮件功能是否开启成功和数据库配置信息:

-- 查询数据库的配置信息
select * from sys.configurations

-- 查看数据库邮件功能是否开启,value 值为1表示已开启,0为未开启
select name,value,description,
       is_dynamic,is_advanced
from sys.configurations
where name like '%mail%'

步骤二:

if exists(SELECT * FROM msdb..sysmail_account WHERE NAME='test') --判断邮件账户名为 test 的账户是否存在
begin
    EXEC msdb..sysmail_delete_account_sp @account_name='test' -- 删除邮件账户名为 test 的账户
end
exec msdb..sysmail_add_account_sp    --创建邮件账户
        @account_name = 'test'      -- 邮件帐户名称
       ,@email_address = '980095349@qq.com'      -- 发件人邮件地址  
       ,@display_name = 'Brambling'       -- 发件人姓名  
       ,@replyto_address = null        -- 回复地址
       ,@description = null            -- 邮件账户描述
       ,@mailserver_name = 'smtp.qq.com'    -- 邮件服务器地址 
       ,@mailserver_type = 'SMTP'        -- 邮件协议
       ,@port = 25                 -- 邮件服务器端口  
       ,@username = '980095349@qq.com'        -- 用户名  
       ,@password = 'xxxxxx'      -- 密码  
       ,@use_default_credentials = 0    -- 是否使用默认凭证,0为否,1为是
       ,@enable_ssl = 1        -- 是否启用 ssl 加密,0为否,1为是
       ,@account_id = null  -- 输出参数,返回创建的邮件账户的ID

PS:如果使用的是QQ邮箱,记得要把参数 @enable_ssl 的值设置为 1 。不然后面会报服务器错误,这个错误搞了我好久,最后终于找到原因了。

步骤三:

if exists(SELECT * FROM msdb..sysmail_profile where NAME = N'SendEmailProfile') --判断名为 SendEmailProfile 的邮件配置文件是否存在
begin  
    exec msdb..sysmail_delete_profile_sp @profile_name = 'SendEmailProfile'  --删除名为 SendEmailProfile 的邮件配置文件
end

exec msdb..sysmail_add_profile_sp    -- 添加邮件配置文件
     @profile_name = 'SendEmailProfile',   -- 配置文件名称    
     @description = '数据库发送邮件配置文件',    -- 配置文件描述      
     @profile_id = NULL        -- 输出参数,返回创建的邮件配置文件的ID

步骤四:

-- 邮件账户和邮件配置文件相关联  
exec msdb..sysmail_add_profileaccount_sp   
     @profile_name = 'SendEmailProfile',   -- 邮件配置文件名称     
     @account_name = 'test',    -- 邮件账户名称       
     @sequence_number = 1    -- account 在 profile 中的顺序,一个配置文件可以有多个不同的邮件账户

好了,到这里 sql 发送邮件的配置就基本结束了。下面创建一个触发器实现用户注册成功后,发送邮件给用户。

首先创建一个表:

1 -- 创建一个表
2 create table T_User
3 (
4     UserID        int        not null    identity(1,1) primary key,
5     UserNo        nvarchar(64)    not null  unique,
6     UserPwd        nvarchar(128)  not null ,
7     UserMail    nvarchar(128)    null
8 )
9 go

然后创建一个 insert 类型的 after 触发器:

 1 create trigger NewUser_Send_Mail
 2 on T_User
 3 after insert
 4 as
 5     declare @UserNo    nvarchar(64)
 6     declare @title    nvarchar(64)
 7     declare @content nvarchar(320)
 8     declare @mailUrl nvarchar(128)
 9 
10     declare @count    int
11 
12     select @count=COUNT(1) from inserted 
13     select @UserNo=UserNo,@mailUrl=UserMail from inserted
14 
15     if(@count>0)
16     begin
17         set @title='注册成功通知'
18         set @content='欢迎您'+@UserNo+'!您已成功注册!通知邮件,请勿回复!'
19         
20         exec msdb.dbo.sp_send_dbmail @profile_name='SendEmailProfile',    -- 邮件配置文件名称
21                                      @recipients=@mailUrl,        -- 邮件发送地址
22                                      @subject=@title,        -- 邮件标题
23                                      @body=@content,    --邮件内容
24                                      @body_format='text'    -- 邮件内容的类型,text 为文本,还可以设置为 html 
25     end
26 go

下面就来测试一下吧:

1 -- 新添加一条数据,用以触发 insert 触发器
2 insert into T_User(UserNo,UserPwd,UserMail) values('demo1','123456','1171588826@qq.com')

 执行上面的语句之后,大概两三秒钟,就会收到邮件了(如果没有出现错误的话)。如果没有收到邮件可以使用下面的语句查看邮件发送情况。

use msdb
go
select * from sysmail_allitems        -- 邮件发送情况,可以用来查看邮件是否发送成功

select * from sysmail_mailitems        -- 发送邮件的记录

select * from sysmail_event_log            -- 数据库邮件日志,可以用来查询是否报错
use msdb  
go
--为角色名为 dba 的角色赋予发送数据库邮件的权限
create user dba for login dba    
go  
exec dbo.sp_addrolemember @rolename   = 'DatabaseMailUserRole',  
                          @membername = 'dba'  
go  
use msdb  
go  
    --为角色名为 dba 的角色赋予配置文件发送邮件的权限
exec sysmail_add_principalprofile_sp @principal_name = 'dba',        -- 角色名称
                                     @profile_name = 'SendEmailProfile',  -- 配置文件名称
                                     @is_default = 1    -- 对于角色所拥有的配置文件的顺序,一个数据库角色可以有多个配置文件的权限

如果所使用的登陆数据库会话的角色没有发送数据库邮件的权限,那么也会报错。所以上面是赋予角色发送数据库邮件的权限 sql 语句。

参考:

http://blog.csdn.net/abclm/article/details/6341843

转载于:https://www.cnblogs.com/Brambling/p/6746710.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值