六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

分享SQL Server 使用觸發(fā)器(trigger)發(fā)送電子郵件案例代碼

[摘要]本文分步驟給大家詳細介紹了SQL Server 使用觸發(fā)器(trigger)發(fā)送電子郵件的方法,需要的朋友可以參考下sql 使用系統(tǒng)存儲過程 sp_send_dbmail 發(fā)送電子郵件語法:sp_send_dbmail [ [ @profile_name = ] profile_name ][ ,...
本文分步驟給大家詳細介紹了SQL Server 使用觸發(fā)器(trigger)發(fā)送電子郵件的方法,需要的朋友可以參考下

sql 使用系統(tǒng)存儲過程 sp_send_dbmail 發(fā)送電子郵件語法:

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 發(fā)送電子郵件:

步驟一:

-- 啟用 sql server 郵件的功能
exec sp_configure 'show advanced options',1
go
reconfigure;
go
exec sp_configure 'Database Mail XPs',1
go
reconfigure;
go

如果上面的語句執(zhí)行失敗,也可以使用下面的語句。

-- 啟用 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

使用下面的語句查看數(shù)據(jù)庫郵件功能是否開啟成功和數(shù)據(jù)庫配置信息:

-- 查詢數(shù)據(jù)庫的配置信息
select * from sys.configurations
-- 查看數(shù)據(jù)庫郵件功能是否開啟,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  --創(chuàng)建郵件賬戶
    @account_name = 'test'   -- 郵件帳戶名稱
    ,@email_address = '[email protected]'   -- 發(fā)件人郵件地址 
    ,@display_name = 'Brambling'    -- 發(fā)件人姓名 
    ,@replyto_address = null    -- 回復地址
    ,@description = null      -- 郵件賬戶描述
    ,@mailserver_name = 'smtp.qq.com'  -- 郵件服務器地址 
    ,@mailserver_type = 'SMTP'    -- 郵件協(xié)議
    ,@port = 25         -- 郵件服務器端口 
    ,@username = '[email protected]'    -- 用戶名 
    ,@password = 'xxxxxx'   -- 密碼 
    ,@use_default_credentials = 0  -- 是否使用默認憑證,0為否,1為是
    ,@enable_ssl = 1    -- 是否啟用 ssl 加密,0為否,1為是
    ,@account_id = null -- 輸出參數(shù),返回創(chuàng)建的郵件賬戶的ID

PS:如果使用的是QQ郵箱,記得要把參數(shù) @enable_ssl 的值設(shè)置為 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 = '數(shù)據(jù)庫發(fā)送郵件配置文件',  -- 配置文件描述   
   @profile_id = NULL    -- 輸出參數(shù),返回創(chuàng)建的郵件配置文件的ID

步驟四:

-- 郵件賬戶和郵件配置文件相關(guān)聯(lián) 
exec msdb..sysmail_add_profileaccount_sp  
   @profile_name = 'SendEmailProfile',  -- 郵件配置文件名稱   
   @account_name = 'test',  -- 郵件賬戶名稱    
   @sequence_number = 1  -- account 在 profile 中的順序,一個配置文件可以有多個不同的郵件賬戶

好了,到這里 sql 發(fā)送郵件的配置就基本結(jié)束了。下面創(chuàng)建一個觸發(fā)器實現(xiàn)用戶注冊成功后,發(fā)送郵件給用戶。

首先創(chuàng)建一個表:

-- 創(chuàng)建一個表
 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

然后創(chuàng)建一個 insert 類型的 after 觸發(fā)器:

 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,    -- 郵件發(fā)送地址
                   @subject=@title,    -- 郵件標題
                   @body=@content,  --郵件內(nèi)容
                   @body_format='text'  -- 郵件內(nèi)容的類型,text 為文本,還可以設(shè)置為 html 
   end
 go

下面就來測試一下吧:

 -- 新添加一條數(shù)據(jù),用以觸發(fā) insert 觸發(fā)器
 insert into T_User(UserNo,UserPwd,UserMail) values('demo1','123456','[email protected]')

執(zhí)行上面的語句之后,大概兩三秒鐘,就會收到郵件了(如果沒有出現(xiàn)錯誤的話)。如果沒有收到郵件可以使用下面的語句查看郵件發(fā)送情況。

use msdb
go
select * from sysmail_allitems    -- 郵件發(fā)送情況,可以用來查看郵件是否發(fā)送成功
select * from sysmail_mailitems    -- 發(fā)送郵件的記錄
select * from sysmail_event_log      -- 數(shù)據(jù)庫郵件日志,可以用來查詢是否報錯
use msdb 
go
--為角色名為 dba 的角色賦予發(fā)送數(shù)據(jù)庫郵件的權(quán)限
create user dba for login dba  
go 
exec dbo.sp_addrolemember @rolename  = 'DatabaseMailUserRole', 
             @membername = 'dba' 
go 
use msdb 
go 
  --為角色名為 dba 的角色賦予配置文件發(fā)送郵件的權(quán)限
exec sysmail_add_principalprofile_sp @principal_name = 'dba',    -- 角色名稱
                   @profile_name = 'SendEmailProfile', -- 配置文件名稱
                   @is_default = 1  -- 對于角色所擁有的配置文件的順序,一個數(shù)據(jù)庫角色可以有多個配置文件的權(quán)限

如果所使用的登陸數(shù)據(jù)庫會話的角色沒有發(fā)送數(shù)據(jù)庫郵件的權(quán)限,那么也會報錯。所以上面是賦予角色發(fā)送數(shù)據(jù)庫郵件的權(quán)限 sql 語句。

以上就是分享SQL Server 使用觸發(fā)器(trigger)發(fā)送電子郵件實例代碼的詳細內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學習教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 亚洲入口| 中文字幕专区高清在线观看 | 中文字幕一区在线观看视频 | 日韩激情视频 | 婷婷色九月综合激情丁香 | 啪啪欧美 | 婷婷在线视频观看 | 日韩成人小视频 | 青青草原影院 | 天天影视色香欲综合网天天录日日录 | 欧美野外多人交3 | 亚洲最大成人 | 日本免费不卡在线一区二区三区 | 日韩一级黄色大片 | 五月婷婷丁香 | 深爱激情五月婷婷 | 亚洲欧美视频网站 | 天天看天天摸色天天综合网 | 日韩中文字幕在线免费观看 | 香港三级欧美国产精品 | 青春草在线视频观看 | 日本红怡院亚洲红怡院最新 | 五月婷婷之婷婷 | 亚洲一色| 性喷潮久久久久久久久 | 日本色站 | 天天干天天插天天 | 午夜不卡福利 | 中文字幕乱偷乱码亚洲 | 色久天| 日本在线视频网 | 天天躁日日躁狠狠躁视频下载播二 | 五月天伊人网 | 午夜国产精品福利在线观看 | 日本aⅴ在线不卡免费观看 日本aⅴ在线 | 日产国产欧美韩国在线 | 色偷偷影院 | 日本中文在线观看 | 欧美午夜色大片在线观看免费 | 中文字幕三级在线不卡 | 欧美一级视频高清片 |