设为首页 收藏本站
查看: 1223|回复: 0

[经验分享] SQL Server 使用触发器(trigger)发送电子邮件

[复制链接]

尚未签到

发表于 2017-12-13 20:52:45 | 显示全部楼层 |阅读模式
  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 发送电子邮件:
  步骤一:
  

  
exec sp_configure 'show advanced options',1
  
go
  
reconfigure;
  
go
  

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

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

  
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
  

  

  
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')  
begin
  EXEC msdb..sysmail_delete_account_sp @account_name='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   
  ,@enable_ssl = 1        
  ,@account_id = null  
  

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

if exists(SELECT * FROM msdb..sysmail_profile where NAME = N'SendEmailProfile')  
begin  
  exec msdb..sysmail_delete_profile_sp @profile_name = 'SendEmailProfile'  
  
end
  

  
exec msdb..sysmail_add_profile_sp   
  @profile_name = 'SendEmailProfile',   
  @description = '数据库发送邮件配置文件',   
  @profile_id = NULL        
  

  步骤四:
  

  
exec msdb..sysmail_add_profileaccount_sp   
  @profile_name = 'SendEmailProfile',   
  @account_name = 'test',   
  @sequence_number = 1   
  

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

  
create table T_User
  
(

  
     UserID        int        not null   >  
     UserNo        nvarchar(64)    not null  unique,
  
     UserPwd        nvarchar(128)  not null ,
  
     UserMail    nvarchar(128)    null
  
)
  
go
  

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

create trigger NewUser_Send_Mail  

on T_User  

after insert  
as
  
     declare @UserNo    nvarchar(64)
  
     declare @title    nvarchar(64)
  
     declare @content nvarchar(320)
  
     declare @mailUrl nvarchar(128)
  

  
     declare @count    int
  

  
     select @count=COUNT(1) from inserted
  
     select @UserNo=UserNo,@mailUrl=UserMail from inserted
  

  
     if(@count>0)
  
     begin
  
         set @title='注册成功通知'
  
         set @content='欢迎您'+@UserNo+'!您已成功注册!通知邮件,请勿回复!'
  
         
  
         exec msdb.dbo.sp_send_dbmail @profile_name='SendEmailProfile',   
  
                                      @recipients=@mailUrl,        
  
                                      @subject=@title,        
  
                                      @body=@content,   
  
                                      @body_format='text'   
  
     end
  
go
  

  下面就来测试一下吧:
  

  
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  

  
create user dba for login dba   
  
go  
  
exec dbo.sp_addrolemember @rolename   = 'DatabaseMailUserRole',  
  @membername = 'dba'  
  
go  
  

  

use msdb  

go  
exec sysmail_add_principalprofile_sp @principal_name = 'dba',        
  @profile_name = 'SendEmailProfile',  
  @is_default = 1   
  

  如果所使用的登陆数据库会话的角色没有发送数据库邮件的权限,那么也会报错。所以上面是赋予角色发送数据库邮件的权限 sql 语句。
  参考:
  http://blog.csdn.net/abclm/article/details/6341843

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-423801-1-1.html 上篇帖子: sql server 执行计划(execution plan)介绍 下篇帖子: SQL Server 创建游标(cursor)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表