当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL邮件自动应答

MSSQL
将表数据生成SQL脚本的存储过程和工具
初学者必读:经典的数据库记录分页代码
使用SQL Server 2008管理非结构化数据
利用索引提高SQL Server数据处理的效率
SQL Server数据库内存会不断增加的问题分析
面向对象设计过程中必须遵守的相关准则
SQL Server 2005如何设置多字段做关键字
SQL Server 2005数据库中表的递归查询
SQL Server中使用DTS设计器进行数据转移
在查询分析器理启动或停止SQL Agent服务
教你快速掌握SQL语言中游标的使用技巧
将SQL Server中所有表的列信息显示出来
使用SQL语句快速获取SQL Server数据字典
Sql Server 2005中的架构用户登录和角色
如何保存数据库连接参数代码及步骤详解
如何使用SQL Server数据库嵌套子查询
SQL Server从安装到建库为新手寻找捷径
课程讲解 如何使用SQL Server校勘功能
数据库理论:学习基于SQL数据库的算法
教你使用SQL Server数据库进行网络链接

MSSQL 中的 SQL邮件自动应答


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 117 ::
收藏到网摘: n/a

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  
 /*&nb