以下的文章主要描述的是正确建立SQL Server 2005邮件的实际操作步骤,我们大家都知道数据库邮件(Database MAIl)是 SQL Server 2005数据库引擎中最新增的一项比较简单实用的功能。
Database Mail代替了SQL Mail,它使用一个简单SQL Server 2005邮件传输协议( *** TP)服务器,而不是SQL Mail所要求的MAPI账号来发送电子邮件。
这允许你的组织发送带附件和查询结果的电子邮件,附加查询结果,以及格式化HTML电子邮件。你还可以用它设定许多其它配置,而不需要你拥有一台Exchange服务器或配置任何类型的MAPI工作区。
使用Database Mail的好处
除完全以 *** TP为基础外,Database Mail还具有许多其它优点:
它在数据库引擎以外运行,因此对数据库引擎的压力最小。
它支持群集,完全支持群集环境。
它的用户资料(Profile)允许使用冗余 *** TP服务器。(我将在本文后部分详细讨论这一点。)
它允许你以参数的形式向存储过程发送查询文本,存储过程将执行查询并在电子邮件中发送结果。
消息通过一个Service Broker队列异步传送,因此你在发送电子SQL Server 2005邮件时不必等待回应。
它为电子邮件发送提供多重安全保护,如一个控制附件扩展名的过滤器和一个附件大小管理器。
建立和使用Database Mail
在建立一个Database Mail解决方案前,你需要进行一些规划工作。首先,你必须具有一台有效的 *** TP服务器来传送电子邮件。假如你没有 *** TP服务器,请参阅微软知识库文章308161了解建立 *** TP服务器的相关信息。假如你无法确定组织是否拥有 *** TP服务器,询问你的 *** 管理员获得机器名称或服务器的IP地址。你的 *** 管理员可能需要对服务器进行配置,以便SQL Server能够发送电子邮件。
在Database Mail中,账户(Account)保存数据库引擎用来发送电子SQL Server 2005邮件消息的信息。一个账户只为一台电子邮件服务器保存信息,如账户名、电子邮件地址、回复电子邮件地址、服务器名称或IP地址,以及一些可选的安全设置。
要发送一封Database Mail电子邮件,必须使用一个用户资料(Profile)。用户资料为一个或几个账户设立。这种用户资料-账户设置非常有用。它允许你将几个账户和一个用户资料联系起来,这意味着你可以将几台电子邮件服务器和一个用户资料联系起来。
因此,当你试图发送一封电子邮件时,系统会尝试用户资料中的每个账户,直到消息被成功发送出去。假如一台或几台 *** TP服务器出现故障,这种设置就十分有用。它还允许你开发发送电子邮件的应用程序代码,而不必担心针对不同的环境修改Profile名称。你可以在开发和生产环境中使用相同的Profile名称,唯一的差别在于用户资料中包含的账户有所不同。
该是时候了解如何建立一个Database Mail账户了。在我们的例子中,我假设你正坐在一台你具有系统管理员访问权限的开发机器前。假如你没有系统管理员权限,你需要成为msdb数据库DatabaseMailUserRole的一员。
下面的脚本建立一些我在整个实例中都要用到的变量。注意:整个脚本将在msdb数据库中运行,Database Mail对象就保存在其中。
USE msdb go DECLARE @ProfileName VARCHAR(255) DECLARE @AccountName VARCHAR(255) DECLARE @ *** TPAddress VARCHAR(255) DECLARE @EmailAddressVARCHAR(128) DECLARE @DisplayUser VARCHAR(128)
这里我建立了ProfileName、AccountName、stMP服务器名称以及显示在电子SQL Server 2005邮件From(邮件来自)框中的地址。
SET @ProfileName = 'DBMailProfile'; SET @AccountName = 'DBMailAccount'; SET @ *** TPAddress = 'mail.your *** tpserver.com'; SET @EmailAddress = 'DBMail@your *** tpserver.com'; SET @DisplayUser = 'The Mail Man';
下面的的脚本完成一些清理工作,以便假如我再次运行脚本,就不必担心出现错误。
IF EXISTS ( SELECT * FROM msdb.dbo.sy *** ail_profileaccount pa JOIN msdb.dbo.sy *** ail_profile p>下面的脚本给系统增加账户(Account)、用户资料(Profile)和账户-用户资料(Account-Profile)关系。
EXECUTE msdb.dbo.sy *** ail_add_account_sp @account_name = @AccountName, @email_address = @EmailAddress, @display_name = @DisplayUser, @mailserver_name = @ *** TPAddress EXECUTE msdb.dbo.sy *** ail_add_profile_sp @profile_name = @ProfileName EXECUTE msdb.dbo.sy *** ail_add_profileaccount_sp @profile_name = @ProfileName, @account_name = @AccountName, @sequence_number = 1 ;
现在一切都已经准备妥当,我将发送一封测试电子邮件。
EXEC msdb.dbo.sp_send_dbmail @recipients=N'chapman.tim@gmail.com', @body= 'Test Email Body', @subject = 'Test Email Subject', @profile_name = @ProfileName
要检查消息是否发送成功,我可以对sy *** ail_allitems系统视图执行一次查询。
SELECT * FROM sy *** ail_allitems
以上的相关内容就是对建立SQL Server 2005数据库邮件的介绍,望你能有所收获。
扫描二维码推送至手机访问。
版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。
对于Windows 7系统来说,其默认安装的许多工具是我们很少使用或从来不用的,比如系统自带的扫雷、纸牌游戏等。删除此类长期不用的系统组件,不但可以让系统更清爽,更重要的是还可以提高系统的运行速度,特别是对于硬件配置相对较低的上网本来说,尤其如此。接下来,笔者就给大家介绍一下如何删除Windows...
有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...
国外媒体CNET NEWS就这个“上帝模式”和微软Windows部门主管Steven Sinofsky进行邮件交流后得知,这其实只是众多快捷方式中的一个,Sinofsky在邮件里给出了十多个这类快捷方式的关键字符串。 它们的建立方法和之前的“上帝模式”一样,在任意位置新建的一个文件夹,然后改名即可...
北京时间1月13日消息,根据计划,微软将于2015年1月13日正式结束对Windows 7SP1的“主流支持”,而这也标志着“扩展支持”阶段的开始,这个阶段将于2020年1月14日结束。 2013年10月份,微软终止销售独立的Windows 7系统安装包,并要求制造商于2014年10月份停止生...
Intel会在2015年推出Broadwell、Skylake两代14nm处理器,前者可以使用9系芯片组,Skylake升级到了LGA1151插槽,需要搭配新的100系列芯片组,但初期的Skylake-S又不能超倍频,所以今年Q2季度开始会很混杂。Skylake一代会支持DDR4,100系列芯片组升...
最近一些Windows 7用户反馈说,自己在截屏的时候出现黑屏,导致自己截的图黑呼呼一片。这个问题该怎么解决?今天小编就为大家提供一个解决的方法。 步骤 1 在windows xp时代,很多用户都曾被视频截图后的“全黑图片”困扰。对此,在解决本地播放时出现的截图变黑问题,一般有两个方法可以用来解...