分享SQL Server 使用触发器(trigger)发送电子邮件实例代码
技术百科
零下一度
发布时间:2017-04-26
浏览: 次 本文分步骤给大家详细介绍了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 ]
下面开始配置 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 -- 输出参数,返回创建的邮件账户的IDPS:如果使用的是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 语句。
# 多个
# 可以使用
# 创建一个
# 如果没有
# 配置文件
# 报错
# 会报
# 邮件发送
# 发送邮件
# 发送电子邮件
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- 微信里的php文件怎么变mp4_微信接收php转m
- 用Python构建微服务架构实践_FastAPI与
- php怎么捕获异常_trycatch结构处理运行时
- mac本地php环境如何开启curl_curl扩展
- Win11如何设置自动关机 Win11定时关机命令
- Win11怎么查看局域网电脑_Windows 11
- 如何在 Go 中判断变量是否为函数类型
- Win10系统字体模糊怎么办_Windows10高
- Win10怎样设置闹钟贪睡时间 Win10闹钟贪睡
- Windows 10怎么隐藏特定更新补丁_Wind
- 如何使用Golang sync.Map实现并发安全
- 如何在Golang中使用内置函数_Golangle
- Win11怎么设置默认邮件应用_Windows11
- MAC怎么用连续互通相机里的“桌上视角”_MAC在
- Win11怎么设置开机自动连接宽带_Windows
- 如何在 Go 开发中正确处理本地包导入与远程模块路
- Win11怎么更改计算机名_Windows11系统
- Windows蓝屏错误0x0000002C怎么解决
- 如何使用Golang table-driven基准
- 如何在 Go 结构体中正确初始化 map 字段
- Python lxml的etree和Element
- MAC怎么使用表情符号面板_MAC Emoji快捷
- Windows蓝屏BAD_POOL_HEADER故
- 如何在 ACF 中正确更新嵌套多层的 Group
- Win10系统怎么查看网络连接状态_Windows
- php与c语言在嵌入式中有何区别_对比两者在硬件控
- 如何在Mac上搭建Golang开发环境_使用Hom
- Win11怎么更改输入法顺序_Win11调整语言首
- Win11怎么更改电脑名称_Windows 11修
- Linux怎么实现内网穿透_Linux安装Frp客
- C++ STL算法库怎么用?C++常用算法函数(s
- Win10如何更改用户账户控制_Windows10
- Win11任务栏怎么调到左边_Win11开始菜单居
- win11如何清理传递优化文件 Win11为C盘瘦
- 如何在Golang中写入JSON文件_保存结构体数
- Windows 10自带杀毒软件在哪_Window
- Win10怎样清理C盘Steam游戏缓存_Win1
- c++中如何求一个数的平方根_c++ sqrt函数
- Windows音频驱动无声音原因解析_声卡驱动错误
- c++中如何进行二进制文件读写_c++ read与
- mac怎么分屏_MAC双屏显示与分屏操作技巧【指南
- 如何在Windows中创建新的用户账户?(标准与管
- Python技术债务管理_长期维护解析【教程】
- Python音视频处理高级项目教程_FFmpegP
- Win11怎么关闭定位服务_保护Win11位置隐私
- Win11怎么查看显卡温度 Win11任务管理器查
- Windows10如何更改任务栏高度_Win10解
- Python包结构设计_大型项目组织解析【指导】
- 如何正确访问 Laravel 模型或对象的属性而非
- Win11怎样安装钉钉客户端_Win11安装钉钉教

文件可以有多个不同的邮件账户
QQ客服