侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

数据库  /  管理员 发布于 5年前   348

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',1goreconfigure;goexec sp_configure 'Database Mail XPs',1goreconfigure;go

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

-- 启用 sql server 邮件的功能exec sp_configure 'show advanced options', 1goreconfigure with overridegoexec sp_configure 'Database Mail XPs', 1goreconfigure with overridego

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

-- 查询数据库的配置信息select * from sys.configurations-- 查看数据库邮件功能是否开启,value 值为1表示已开启,0为未开启select name,value,description,    is_dynamic,is_advancedfrom sys.configurationswhere 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 的账户endexec msdb..sysmail_add_account_sp  --创建邮件账户    @account_name = 'test'   -- 邮件帐户名称    ,@email_address = '[email protected]'   -- 发件人邮件地址     ,@display_name = 'Brambling'    -- 发件人姓名     ,@replyto_address = null    -- 回复地址    ,@description = null      -- 邮件账户描述    ,@mailserver_name = 'smtp.qq.com'  -- 邮件服务器地址     ,@mailserver_type = 'SMTP'    -- 邮件协议    ,@port = 25         -- 邮件服务器端口     ,@username = '[email protected]'    -- 用户名     ,@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 的邮件配置文件endexec 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','[email protected]')

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

use msdbgoselect * 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 获取所有上级的实现方法
    下一条:
    MSSQL 2000 使用帮助(sql server简明教程)
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客