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 发送邮件的配置就基本结束了。下面创建一个触发器实现用户注册成功后,发送邮件给用户。
首先创建一个表:
- -- 创建一个表
- 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(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' -- 邮件内容的类型,text 为文本,还可以设置为 html
- end
- go
下面就来测试一下吧:
- -- 新添加一条数据,用以触发 insert 触发器
- insert into T_User(UserNo,UserPwd,UserMail) values('demo1','','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
SQL Server 使用触发器(trigger)发送电子邮件的更多相关文章
- SQL Server DDL触发器运用
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 基础知识(Rudimentary Knowledge) DDL运用场景(DDL Scene) ...
- SQL Server:触发器详解
1. 概述 触发器是一种特殊的存储过程,它不能被显式地调用,而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活. 所以触发器可以用来实现对表实施复杂的完整性约束. 2. 触发器的分类 SQL S ...
- 数往知来SQL SERVER 视图 触发器 <九>
SQL server学习_视图 1.视图 视图其实是一张虚拟表,他是一张表的部分数据或多张表的综合数据(视图就是把SQL语句封装起来) 可以看做是一个结果集,但是不是一个结果集 视图不具备存储数据的能 ...
- 记一次SQL Server Insert触发器编写过程
实现功能:新增特定类型的新闻时,自动追加特定的背景图片. 第一版(错误信息:不能在 'inserted' 表和 'deleted' 表中使用 text.ntext 或 image 列),代码如下: - ...
- 【SQL SERVER】触发器(一)
下面是个人对触发器知识的整理,触发器其实很简单,但想要编写发杂的触发器操作还是需要一定的SQL语句编写,触发器主要用于SQL SERVER约束.默认值和规则的完整性检查,还可以实现由主键和外键不能保证 ...
- sql server中触发器
触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 触发器对表进行插入.更新.删 ...
- sql server知道触发器名如何查看里面代码
以sqlserver2008为例,可以写代码查看,也可以通过SQL Server Manager Studio工具的树形列表查看. 一.代码查看: 直接在SQL Server Manager Stud ...
- SQL Server 创建触发器(trigger)
update 触发器: if(OBJECT_ID('trigger_compost_up') is not null) drop trigger trigger_compost_up go creat ...
- SQL Server DDL触发器
DDL 触发器作用: DDL 触发器主要用于防止对数据库架构.视图.表.存储过程等进行的某些修改. DDL 触发器事件: DDL 触发器在创建用来监视并响应该数据库或服务器实例中的活动的事件通知时,可 ...
随机推荐
- 【vijos】1164 曹冲养猪(中国剩余定理)
https://vijos.org/p/1164 好赞orz. 对于求一组线性同余方程 x=a[i](mod m[i]) 这里任意两个m[i]和m[j]都互质 那么可以用中国剩余定理来做. 对中国剩余 ...
- 【POJ】1094 Sorting It All Out(拓扑排序)
http://poj.org/problem?id=1094 原来拓扑序可以这样做,原来一直sb的用白书上说的dfs............ 拓扑序只要每次将入度为0的点加入栈,然后每次拓展维护入度即 ...
- form 回车键(ENTER)
<form class="clb_yyxx_nr" name="appointment_content" action="" onsu ...
- css 五角星 (转)
1.前言 之前做的好几个项目中,都会遇到打分,评分,点赞这样的需求,写了很多次,每次需要再写的时候,就会翻出之前写过的代码,然后copy过来.总觉得这样的话没有进步,没有把知识放进脑袋里,所以,自己花 ...
- hdu 1201:18岁生日(水题,闰年)
18岁生日 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- 漫游kafka实战篇之搭建Kafka开发环境(3)
上篇文章中我们搭建了kafka的服务器,并可以使用Kafka的命令行工具创建topic,发送和接收消息.下面我们来搭建kafka的开发环境. 添加依赖 搭建开发环境需要引入kafka的jar包 ...
- Socket 进行发送
最灵活的通信方式还是Socket ,TcpClient和Tcplistener只是对Socket进行了一些包装,从而使他们使用起来更简单一些 给出同步的服务器端 static void Main(st ...
- 使用ProcDump工具抓取dump
首先得到要抓取的进程号 cd %windir%\syswow64\inetsrvappcmd list wp得到pid之后, 在任务管理器里发现w3wp.exe的CPU总在49%-60%左右, 间歇性 ...
- JSON-Server 安装
在后台还没给接口之前,使用JSON-Server搭建一台JSON服务器,将接口要返回的数据放在json文件里面.然后请求这些数据,这样我们可以先做一些东西,等后台接口好了之后直接替换就可以了,不必一直 ...
- 让iOS应用支持不同版本的系统与设备
本文转载至 http://blog.csdn.net/pucker/article/details/11980811 最近一直在做app的iOS 6和7的同时适配工作,所以在此介绍一下系统与设备的兼 ...