快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

SQL邮件自动应答

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  
 begin  
  select @mapifailure=1  
 end  
  
  
    if ((@subject IS NULL) OR (@subject=@msgsubject))  
    begin  
 /* generate random filename */  
 select @filename=’SQL’ + convert(varchar,ROUND(RAND()*100000,0)) + ’.’ + @filetype  
  
 exec @status = master.dbo.xp_sendmail  
--   @recipients=@originator,  
   @recipients=@originator_address,  
   @copy_recipients=@cc_list,  
   @message=@query,  
   @query=@query,  
   @subject=’Query Results’,  
   @separator=@separator,  
   @width=256,  
   @attachments=@filename,  
   @attach_results=’true’,  
   @no_output=’false’,  
   @echo_error=’true’,  
   @set_user=@set_user,  
   @dbuse=@dbuse  
  
 if @status <> 0  
  begin  
   select @mapifailure=1  
   break  
  end  
  
 select @messages=@messages+1  
  
 exec master.dbo.xp_deletemail @current_msg  
  
    end /* end of xp_sendmail block */  
  end  /* end of xp_findnextmsg loop */  
  
  /* finished examining the contents of inbox;  now send results */  
  if @mapifailure=1  
       begin  
  raiserror(15079,-1,-1,@messages)  
  return(1)  
 end  
  else  
 return(0)  
-- sp_processmail  
3:在master数据库下建一个存储过程
use master
create proc answerMail
as
sp_processmail  @subject = ’sql’,@filetype = ’CSV’,@separator =’,’,@set_user = ’dbo’ ,@dbuse =  ’数据库名’ 

4: 用job调度此存储过程。
5: 现在可以测试了。发一封邮件给服务器上配置的邮箱地址。
主题为  sql
内容为 一句简朴的查询语句 eg:  select getdate()
发送
6: 等到job调度时间到后即可收到回复。
返回类别: 教程
上一教程: 利用MSSQL sp自制未公开的加密函数
下一教程: SQL数据操作基础(中级)9

您可以阅读与"SQL邮件自动应答"相关的教程:
· SQL邮件自动应答
· 使用SQL MAIL收发和自动处理邮件中的扩展存储过程简介
· 启动SQL SERVER时自动执行存储过程
· SQL SERVER EXPRESS数据库自动部署问题及解决
· 设定SQL SERVER定期自动备份数据库
    微笑服务 优质保证 索取样品