SQL邮件自动应答(根据收到的邮件中的查询语句回复语句执行结果)

原创 2004年05月19日 13:38:00

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调度时间到后即可收到回复。

 

(以上在 windows2000 + SQL2000+Microsoft Outlook上测试通过)

 

Postfix接收邮件后转向执行特定的脚本

在Postfix邮件服务器搭建过程中,有时候会希望Postfix接收到邮件之后,能够转向执行特定的脚本。与之相类似的实际功能有,邮件自动回复程序、邮件内容过滤等。这个的功能可...
  • shiyuan0
  • shiyuan0
  • 2015年03月19日 11:35
  • 1268

自动发带查询结果附件的邮件

自动发带查询结果附件的邮件 一:背景 我们日常工作中,可能每天都要反馈一个固定查询结果集,比如日报。 为了减轻工作量,实现自动化管理,所以想通过作业的方式将查询结果附件自动发给收件人。 例如:这里要把...
  • YABIGNSHI
  • YABIGNSHI
  • 2014年01月24日 09:58
  • 1717

mybatis下使用log4j打印sql语句和执行结果

本来以为很简单的问题, 结果自己搞了半天还是不行; 然后google, baidu, 搜出来各种方法, 有加slf4j*.jar的,有说去掉slf4j*.jar,还有说要配置mybatis.cfg.x...
  • jcxch
  • jcxch
  • 2016年08月07日 15:39
  • 1474

SQL Select查询原理--查询语句执行原则(基础)

1.单表查询:根据WHERE条件过滤表中的记录,形成中间表(这个中间表对用户是不可见的);然后根据SELECT的选择列选择相应的列进行返回最终结果。 1)简单的单表查询 SELECT 字段  FR...
  • xunzaosiyecao
  • xunzaosiyecao
  • 2014年04月13日 09:54
  • 2294

java执行SQL语句实现查询的通用方法

查询的结果集保存并返回调用函数 结果集中数据存储到类型的Vector容器中,同时可以被多种类型调用 /* * 执行sql查询语句 */ public static Vector ex...
  • woaini1115077272
  • woaini1115077272
  • 2015年08月22日 09:42
  • 12741

常用的英文邮件语句

工作邮件中常用的英文语句收集整理,告别英文邮件小白!
  • wanghantong
  • wanghantong
  • 2014年07月09日 10:40
  • 2066

PL/SQL 下SQL结果集以html形式发送邮件

在运维的过程中,有时候需要定时将SQL查询的数据结果集以html表格形式发送邮件,因此需要将SQL查询得到的结果集拼接成html代码。对于这种情形通常有二种方式来完成。一是直接使用cron job来定...
  • robinson_0612
  • robinson_0612
  • 2014年01月24日 16:47
  • 4786

SQL逻辑查询语句执行顺序

我的抱怨 我一个搞应用开发的,非要会数据库,这不是专门的数据库开发人员干的事么?话说,小公司也没有数据库开发人员这么个职位吧。好吧,对数据库最深的印象还停留在大学《数据库原理》这堂课上,什么第一范式...
  • q959249819
  • q959249819
  • 2016年07月26日 14:34
  • 1565

SQL Select语句完整的执行顺序

SQL Select语句完整的执行顺序:  1、from子句组装来自不同数据源的数据;  2、where子句基于指定的条件对记录行进行筛选;  3、group by子句将数据划分为多个分组;  ...
  • wozengcong
  • wozengcong
  • 2015年01月05日 16:49
  • 3758

executeBatch()批量执行Sql语句

executeBatch()方法:用于成批地执行SQL语句,但不能执行返回值是ResultSet结果集的SQL语句,而是直接执行stmt.executeBatch(); addBatch():向批处...
  • u011389474
  • u011389474
  • 2016年10月14日 14:46
  • 3951
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQL邮件自动应答(根据收到的邮件中的查询语句回复语句执行结果)
举报原因:
原因补充:

(最多只允许输入30个字)