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

发布时间 - 2026-01-11 00:46:20    点击率:

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 发送邮件的配置就基本结束了。下面创建一个触发器实现用户注册成功后,发送邮件给用户。

首先创建一个表:

-- 创建一个表
 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_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() 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'  -- 邮件内容的类型,text 为文本,还可以设置为 html 
   end
 go

下面就来测试一下吧:

 -- 新添加一条数据,用以触发 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 语句。

以上所述是小编给大家介绍的SQL Server 使用触发器(trigger)发送电子邮件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# sql  # trigger  # 发送邮件  # server  # sqlserver  # sql server中的触发器用法实例详解  # SQL Server的触发器详解  # SQL SERVER触发器详解  # SQL Server的触发器你了解多少  # 利用SQL Server触发器实现表的历史修改痕迹记录  # SQLSERVER对加密的存储过程、视图、触发器进行解密(推荐)  # SQL Server:触发器实例详解  # SQL server 三种常用的触发器  # 配置文件  # 创建一个  # 多个  # 邮件发送  # 如果没有  # 发送电子邮件  # 可以使用  # 报错  # 会报  # 设置为  # 小编  # 邮件服务器  # 是否存在  # 可以用来  # 的是  # 注册成功  # 就会  # 好了  # 也会 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何在 Pandas 中基于一列条件计算另一列的分组均值  如何在橙子建站上传落地页?操作指南详解  如何实现建站之星域名转发设置?  如何在建站宝盒中设置产品搜索功能?  laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法  香港服务器建站指南:免备案优势与SEO优化技巧全解析  如何选择PHP开源工具快速搭建网站?  jQuery中的100个技巧汇总  浅谈Javascript中的Label语句  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Android 常见的图片加载框架详细介绍  高防服务器租用指南:配置选择与快速部署攻略  Java垃圾回收器的方法和原理总结  潮流网站制作头像软件下载,适合母子的网名有哪些?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  实现点击下箭头变上箭头来回切换的两种方法【推荐】  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  图册素材网站设计制作软件,图册的导出方式有几种?  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  Laravel如何保护应用免受CSRF攻击?(原理和示例)  JavaScript如何实现音频处理_Web Audio API如何工作?  如何用美橙互联一键搭建多站合一网站?  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  太平洋网站制作公司,网络用语太平洋是什么意思?  如何快速搭建虚拟主机网站?新手必看指南  Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议  如何快速生成橙子建站落地页链接?  Java解压缩zip - 解压缩多个文件或文件夹实例  如何快速搭建二级域名独立网站?  如何在IIS7上新建站点并设置安全权限?  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  如何快速生成可下载的建站源码工具?  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  Android实现代码画虚线边框背景效果  JS碰撞运动实现方法详解