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