程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL郵件自動應答

SQL郵件自動應答

編輯:關於SqlServer
SQLMail可以收發郵件,可能好多人都有xp_sendmail發送過郵件,這裡介紹一種郵件服務器接收郵件後,根據郵件內容(只能是查詢語句) 把郵件中的查詢語句執行後的結果以附件形式自動返回給發送郵件者。
eg:
發送郵件,郵件內容為: select top 10 id,name from sysobjects則服務器自動回復郵件,內容為上述查詢語句的執行結果,以附件形式發送。

1:當然是先配置好SQL郵件服務了,這方面的資料比較多,此處不贅述。
2: 把sp_processmail稍作修改 (把發件人的郵件地址解析為真正的郵箱地址)
Alter procedure sp_processmail
@subject varchar(255)=NULL,
@filetype varchar(3)=’txt’,
@separator varchar(3)=’tab’,
@set_user varchar(132)=’guest’,
@dbuse varchar(132)=’master’
as

declare @status int
declare @msg_id varchar(64)
declare @originator varchar(255)
declare @originator_address varchar(255)
declare @a varchar(255)
declare @cc_list varchar(255)
declare @msgsubject varchar(255)
declare @query varchar(8000)
declare @messages int
declare @mapifailure int
declare @resultmsg varchar(80)
declare @filename varchar(12)
declare @current_msg varchar(64)

select @messages=0
select @mapifailure=0

if @separator=’tab’ select @separator=CHAR(9)

/* get first message id */
exec @status = master.dbo.xp_findnextmsg
@msg_id=@msg_id output,
@unread_only=’true’

if @status <> 0
select @mapifailure=1

while (@mapifailure=0)
begin

if @msg_id is null break
if @msg_id = ’’ break

exec @status = master.dbo.xp_readmail
@msg_id=@msg_id,
@originator=@originator output,
@cc_list=@cc_list output,
@subject=@msgsubject output,
@message=@query output,
@peek=’true’,
@originator_address= @originator_address output,
@suppress_attach=’true’

if @status <> 0
begin
select @mapifailure=1
break
end

/* get new message id before processing & deleting current */
select @current_msg=@msg_id
exec @status = master.dbo.xp_findnextmsg
@msg_id=@msg_id output,
@unread_only=’true’

if @status <> 0
SQLMail可以收發郵件,可能好多人都有xp_sendmail發送過郵件,這裡介紹一種郵件服務器接收郵件後,根據郵件內容(只能是查詢語句) 把郵件中的查詢語句執行後的結果以附件形式自動返回給發送郵件者。
eg:
發送郵件,郵件內容為: select top 10 id,name from sysobjects則服務器自動回復郵件,內容為上述查詢語句的執行結果,以附件形式發送。

1:當然是先配置好SQL郵件服務了,這方面的資料比較多,此處不贅述。
2: 把sp_processmail稍作修改 (把發件人的郵件地址解析為真正的郵箱地址)
Alter procedure sp_processmail
@subject varchar(255)=NULL,
@filetype varchar(3)=’txt’,
@separator varchar(3)=’tab’,
@set_user varchar(132)=’guest’,
@dbuse varchar(132)=’master’
as

declare @status int
declare @msg_id varchar(64)
declare @originator varchar(255)
declare @originator_address varchar(255)
declare @a varchar(255)
declare @cc_list varchar(255)
declare @msgsubject varchar(255)
declare @query varchar(8000)
declare @messages int
declare @mapifailure int
declare @resultmsg varchar(80)
declare @filename varchar(12)
declare @current_msg varchar(64)

select @messages=0
select @mapifailure=0

if @separator=’tab’ select @separator=CHAR(9)

/* get first message id */
exec @status = master.dbo.xp_findnextmsg
@msg_id=@msg_id output,
@unread_only=’true’

if @status <> 0
select @mapifailure=1

while (@mapifailure=0)
begin

if @msg_id is null break
if @msg_id = ’’ break

exec @status = master.dbo.xp_readmail
@msg_id=@msg_id,
@originator=@originator output,
@cc_list=@cc_list output,
@subject=@msgsubject output,
@message=@query output,
@peek=’true’,
@originator_address= @originator_address output,
@suppress_attach=’true’

if @status <> 0
begin
select @mapifailure=1
break
end

/* get new message id before processing & deleting current */
select @current_msg=@msg_id
exec @status = master.dbo.xp_findnextmsg
@msg_id=@msg_id output,
@unread_only=’true’

if @status <> 0
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved