仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1099|回复: 8
打印 上一主题 下一主题

[学习教程] MSSQL教程之SQL邮件主动应对(依据收到的邮件中的查...

[复制链接]
爱飞 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:32:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
修复过程包含最多4个阶段,在下面描述。在你开始前,你应该cd到数据库目录和检查表文件的权限,确保他们可被运行mysqld的Unix用户读取(和你,因为你需要存取你正在检查的文件)。如果它拒绝你修改文件,他们也必须是可被你写入的。语句|实行
SQLMail能够收发邮件,大概很多多少人都有xp_sendmail发送过邮件,
这里先容一种邮件服务器吸收邮件后,依据邮件内容(只能是查询语句)
把邮件中的查询语句实行后的了局以附件情势主动前往给发送邮件者。

eg:
发送邮件,邮件内容为:selecttop10id,namefromsysobjects
则服务器主动复兴邮件,内容为上述查询语句的实行了局,以附件情势发送。


1:固然是先设置好SQL邮件服务了,这方面的材料对照多,此处不赘述。

2:把sp_processmail稍作修正(把发件人的邮件地点剖析为真实的邮箱地点)

Alterproceduresp_processmail
@subjectvarchar(255)=NULL,
@filetypevarchar(3)=txt,
@separatorvarchar(3)=tab,
@set_uservarchar(132)=guest,
@dbusevarchar(132)=master
as

declare@statusint
declare@msg_idvarchar(64)
declare@originatorvarchar(255)
declare@originator_addressvarchar(255)
declare@avarchar(255)

declare@cc_listvarchar(255)
declare@msgsubjectvarchar(255)
declare@queryvarchar(8000)
declare@messagesint
declare@mapifailureint
declare@resultmsgvarchar(80)
declare@filenamevarchar(12)
declare@current_msgvarchar(64)

select@messages=0
select@mapifailure=0

if@separator=tabselect@separator=CHAR(9)

/*getfirstmessageid*/
exec@status=master.dbo.xp_findnextmsg
@msg_id=@msg_idoutput,
@unread_only=true

if@status0
select@mapifailure=1

while(@mapifailure=0)
begin

if@msg_idisnullbreak
if@msg_id=break

exec@status=master.dbo.xp_readmail
@msg_id=@msg_id,
@originator=@originatoroutput,
@cc_list=@cc_listoutput,
@subject=@msgsubjectoutput,
@message=@queryoutput,
@peek=true,
@originator_address=@originator_addressoutput,
@suppress_attach=true

if@status0
begin
select@mapifailure=1
break
end

/*getnewmessageidbeforeprocessing&deletingcurrent*/
select@current_msg=@msg_id
exec@status=master.dbo.xp_findnextmsg
@msg_id=@msg_idoutput,
@unread_only=true

if@status0
begin
select@mapifailure=1
end


if((@subjectISNULL)OR(@subject=@msgsubject))
begin
/*generaterandomfilename*/
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=QueryResults,
@separator=@separator,
@width=256,
@attachments=@filename,
@attach_results=true,
@no_output=false,
@echo_error=true,
@set_user=@set_user,
@dbuse=@dbuse

if@status0
begin
select@mapifailure=1
break
end

select@messages=@messages+1

execmaster.dbo.xp_deletemail@current_msg

end/*endofxp_sendmailblock*/
end/*endofxp_findnextmsgloop*/

/*finishedexaminingthecontentsofinbox;nowsendresults*/
if@mapifailure=1
begin
raiserror(15079,-1,-1,@messages)
return(1)
end
else
return(0)
--sp_processmail

3:在master数据库下建一个存储历程
usemaster
createprocanswerMail
as
sp_processmail@subject=sql,@filetype=CSV,@separator=,,@set_user=dbo,@dbuse=数据库名


4:
用job调剂此存储历程。

5:
如今能够测试了。
发一封邮件给服务器上设置的邮箱地点。
主题为sql
内容为一句复杂的查询语句eg:selectgetdate()
发送

6:比及job调剂工夫到后便可收到复兴。



(以上在windows2000+SQL2000+MicrosoftOutlook上测试经由过程)


“数据行级锁定”的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT、LOCKINSHAREMODE、SELECT、FORUPDATE命令以及INSERT、UPDATE和DELETE命令。
不帅 该用户已被删除
沙发
发表于 2015-1-19 16:17:53 | 只看该作者
varchar(max)\\\\nvarchar(max)类型的引入大大的提高了编程的效率,可以使用字符串函数对CLOB类型进行操作,这是一个亮点。
精灵巫婆 该用户已被删除
板凳
发表于 2015-1-26 22:52:53 | 只看该作者
多加的系统视图和实时系统信息这些东西对DBA挑优非常有帮助,但是感觉粒度还是不太细。
再现理想 该用户已被删除
地板
发表于 2015-2-4 22:16:10 | 只看该作者
两个月啃那本sqlserver2005技术内部-存储引擎,花了几个月啃四本书
若相依 该用户已被删除
5#
发表于 2015-2-10 21:55:05 | 只看该作者
对一张百万级别的表建游标,同时又没有什么过滤条件,取得游标效率是如果直接SQL查询百万条数据;如果再对每条记录做处理,耗时将更长。
第二个灵魂 该用户已被删除
6#
发表于 2015-3-1 15:52:38 | 只看该作者
财务软件要用SQL也只是后台的数据库而已,软件都是成品的,当然多学东西肯定是有好处的..
柔情似水 该用户已被删除
7#
发表于 2015-3-10 19:52:56 | 只看该作者
groupby子句可以将查询结果分组,并返回行的汇总信息Oracle按照groupby子句中指定的表达式的值分组查询结果。
莫相离 该用户已被删除
8#
发表于 2015-3-17 09:26:56 | 只看该作者
每天坚持做不一样的是,认真做笔录,定时复习。一个月你就可以有一定的收获。当然如果你想在sql方面有一定的造诣,你少不了需要看很多很多的书籍了。
小女巫 该用户已被删除
9#
发表于 2015-3-24 06:03:51 | 只看该作者
索引视图2k就有。但是2005对其效率作了一些改进但是schema.viewname的作用域真是太限制了它的应用面。还有一大堆的环境参数和种种限制都让人对它有点却步。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-23 12:18

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表