SQL Server 使用觸發器(trigger)發送電子郵件

来源:http://www.cnblogs.com/Brambling/archive/2017/04/22/6746710.html
-Advertisement-
Play Games

sql 使用系統存儲過程 sp_send_dbmail 發送電子郵件語法: 參數參考地址:https://docs.microsoft.com/en-us/sql/relational-databases/system-stored-procedures/sp-send-dbmail-transac ...


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 = '[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 的郵件配置文件
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 發送郵件的配置就基本結束了。下麵創建一個觸發器實現用戶註冊成功後,發送郵件給用戶。

首先創建一個表:

1 -- 創建一個表
2 create table T_User
3 (
4     UserID        int        not null    identity(1,1) primary key,
5     UserNo        nvarchar(64)    not null  unique,
6     UserPwd        nvarchar(128)  not null ,
7     UserMail    nvarchar(128)    null
8 )
9 go

然後創建一個 insert 類型的 after 觸發器:

 1 create trigger NewUser_Send_Mail
 2 on T_User
 3 after insert
 4 as
 5     declare @UserNo    nvarchar(64)
 6     declare @title    nvarchar(64)
 7     declare @content nvarchar(320)
 8     declare @mailUrl nvarchar(128)
 9 
10     declare @count    int
11 
12     select @count=COUNT(1) from inserted 
13     select @UserNo=UserNo,@mailUrl=UserMail from inserted
14 
15     if(@count>0)
16     begin
17         set @title='註冊成功通知'
18         set @content='歡迎您'+@UserNo+'!您已成功註冊!通知郵件,請勿回覆!'
19         
20         exec msdb.dbo.sp_send_dbmail @profile_name='SendEmailProfile',    -- 郵件配置文件名稱
21                                      @recipients=@mailUrl,        -- 郵件發送地址
22                                      @subject=@title,        -- 郵件標題
23                                      @body=@content,    --郵件內容
24                                      @body_format='text'    -- 郵件內容的類型,text 為文本,還可以設置為 html 
25     end
26 go

下麵就來測試一下吧:

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

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

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 微信 小程式開始火了,app跨平臺的革命再次高漲,不得不說,不用再擔心android和ios雙版本開發成本,及h5的開發 和apicloud一樣,不需要關註平臺問題,只需要關註前端js、css就能大aodroin和ios上完美相容,贊贊贊~ 那麼apicloud 和 微信小程式又有什麼區別和共通呢? ...
  • 1.裝載器API概述 Class/Interface 說明 LoaderManager 一個抽像類,關聯到一個Activity或Fragment,管理一個或多個裝載器的實例。這幫助一個應用管理那些與Activity或Fragment的生命周期相關的長時間運行的的操作。最常見的方式是與一個Cursor ...
  • 一.基本概念 1.LoaderManager LoaderManager用來負責管理與Activity或者Fragment聯繫起來的一個或多個Loaders對象. 每個Activity或者Fragment都有唯一的一個LoaderManager實例(通過getLoaderManager()方法獲得) ...
  • 圖片載入框架: Glide https://github.com/bumptech/glide Android-Universal-Image-Loader https://github.com/nostra13/Android-Universal-Image-Loader Picasso http ...
  • 運行報錯的原因是sdk沒有下載完整 解決辦法: 1,打開sdk manage。分別下載android support repository、Google play services、google repository這三個sdk的包,當然最新的包也要下載。 下載Extras中選中的三個即可 2,打開 ...
  • < SELECT names Language: English • 中文 namecontinent Afghanistan Asia Albania Europe Algeria Africa Andorra Europe Angola Africa .... name:國家名稱continen ...
  • 對於剛入門的同學來說 可能很少單獨安裝Mysql (大多都使用集成包 例如:wampserver、PHPstudy。因本人寫php 這裡就不多說了)。 由於是第一次安裝百度了大量的信息 此條信息經驗證 可順利安裝 Mysql 地址:http://www.jb51.net/article/92158. ...
  • 資料庫表常用術語 關係 關係即二維表,每一個關係都有一個關係名,就是表名記錄 表中的行欄位 表中的列 也稱屬性域 取值範圍關聯 不同資料庫表之間的數據聯繫關鍵字 屬性或屬性的組合,可以用於唯一標識一條記錄外部關鍵字 表中的一個欄位,不是本表中的關鍵字,而是其他表的關鍵字 數據冗餘 資料庫表中的重覆數 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...