本文分步骤给大家详细介绍了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 的账户是否存在
beginEXEC 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 发送邮件的配置就基本结束了。下面创建一个触发器实现用户注册成功后,发送邮件给用户。

首先创建一个表:

-- 创建一个表create table T_User(UserID    int    not null  identity(1,1) primary key,UserNo    nvarchar(64)  not null unique,UserPwd    nvarchar(128) not null ,UserMail  nvarchar(128)  null)go

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

 create trigger NewUser_Send_Mailon T_Userafter insertasdeclare @UserNo  nvarchar(64)declare @title  nvarchar(64)declare @content nvarchar(320)declare @mailUrl nvarchar(128)declare @count  intselect @count=COUNT() from inserted select @UserNo=UserNo,@mailUrl=UserMail from insertedif(@count>0)beginset @title='注册成功通知'set @content='欢迎您'+@UserNo+'!您已成功注册!通知邮件,请勿回复!'exec msdb.dbo.sp_send_dbmail @profile_name='SendEmailProfile',  -- 邮件配置文件名称@recipients=@mailUrl,    -- 邮件发送地址@subject=@title,    -- 邮件标题@body=@content,  --邮件内容@body_format='text'  -- 邮件内容的类型,text 为文本,还可以设置为 html endgo

下面就来测试一下吧:

 -- 新添加一条数据,用以触发 insert 触发器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://www.jb51.net/article/111801.htm

SQL Server 使用触发器(trigger)发送电子邮件步骤详解相关推荐

  1. SQL Server 2005,2008 正则表达式 替换函数应用详解

    CREATE function dbo.regexReplace ( @source ntext, --原字符串 @regexp varchar(1000), --正则表达式 @replace var ...

  2. 小程序利用云函数发送电子邮件功能详解

    今天分享一个小功能代码,小程序通过云函数发送电子邮件的功能,上学那会觉得邮箱没啥用了,都快淘汰了的东西,但是现在发现还是有点用处的,印象比较深的就是有一个程序,可以给十年后的自己写邮件,如果大家掌握了 ...

  3. mysql identity sql_SQL Server中identity(自增)的用法详解

    一.identity的基本用法 1.含义 identity表示该字段的值会自动更新,不需要我们维护,通常情况下我们不可以直接给identity修饰的字符赋值,否则编译时会报错 2.语法 列名 数据类型 ...

  4. 如何使用SQL Server INSTEAD-OF触发器

    如何使用SQL Server INSTEAD-OF触发器 触发器是类似于存储程序的数据库对象,它响应数据库环境下的某个请求.SQL Sever 2005包含3个触发器对象:AFTER,数据定义语言 ( ...

  5. 实验9 SQL Server 的触发器

    实验9 SQL Server 的触发器 一.实验目的 1.了解触发器的触发过程和类型 2.通过执行SQL脚本,掌握创建触发器并测试触发器 3.掌握通过使用触发器维护数据完整性的方法. 二.实验要求 1 ...

  6. SQL Server:触发器详解

    SQL Server:触发器详解 1. 概述 2. 触发器的分类 3. Inserted和Deleted表 4. 触发器的执行过程 5. 创建触发器 6. 修改触发器: 7. 删除触发器: 8. 查看 ...

  7. SQL Server 2017下载地址、安装步骤

    SQL Server 2017的下载地址 安装步骤 SQL Server 2017的下载地址 安装步骤 请参考如下博客 https://blog.csdn.net/slyh_td/article/de ...

  8. SQL Server 使用企业微信发送消息

    SQL Server使用企业微信发送消息 要推送企业微信消息需要使用WebAPI方式调用下面两个方法: 1.获取Token 请求方式: GET(HTTPS) 请求地址: https://qyapi.w ...

  9. Microsoft SQL Server 2012版下载与安装步骤

    一.下载SQL Server 2012版 下载地址(微软官网):https://www.microsoft.com/zh-cn/download/details.aspx?id=29066 语言默认选 ...

  10. ios php 表单提交图片上传,axios发送post请求提交图片表单步骤详解

    这次给大家带来axios发送post请求提交图片表单步骤详解,axios发送post请求提交图片表单的注意事项有哪些,下面就是实战案例,一起来看一下. DOME 接口const userUploadA ...

最新文章

  1. 程序猿面试什么最重要?
  2. maya表情blendshape_Maya的形状融合变形器Blend Shape | 学步园
  3. 看完这些细分领域别说小程序代理创业没有机会
  4. 一个简单的例子看java线程机制
  5. git锁和钩子以及图形化界面
  6. PHP实现各种经典算法
  7. github哪些协议能商用_GitHub 上有哪些一般人也可以用的项目?
  8. win11右键菜单怎么修改 Windows11修改右键菜单为win10风格的步骤方法
  9. [linux] redhat 7 iptables 配置
  10. 在Winform中实现半透明遮罩层
  11. 拓端tecdat|基于r语言的疾病制图中自适应核密度估计的阈值选择方法案例
  12. JavaWeb开发Servlet学习
  13. 奥多朗WIFI 插座
  14. 快速上手Onvif(Python)心得
  15. 【自学Python:Day2】磨洋工的我一周一课……
  16. H无穷控制学习笔记——H无穷/H2控制
  17. 计算机画图 教学反思,画图教学反思
  18. 2023Java 并发编程面试题
  19. 沈航计算机复试刷人,考研复试刷人严重吗被刷机率大吗
  20. 苹果产品信息查询_苹果维修召回计划 + iPhone辨别真伪

热门文章

  1. 2021年【最后】的抢票机会你抓住了吗?这里有一些抢票攻略!
  2. batch spring 重复执行_Spring Batch_JOB重启机制
  3. 全球及中国体育用品商店行业商业模式分析及投资风险预测2022年版
  4. 多人如何通过小程序上传照片、视频、素材、文章,然后点赞投票评选?
  5. Steam 游戏服务器IP地址段
  6. 浙江工业大学2020考研经验分享
  7. 研发团队管理实践总结
  8. 学计算机高中应选什么科目,新高考选哪些科目可以报计算机?高中生如何进步?...
  9. 一篇文章带你搞定 create connection SQLException, url: jdbc:mysql://10.15.16.63:3306/restful, errorCode 1130
  10. 为什么浏览器网页每次打开都是搜狗?