正确建立SQL Server 2005邮件的实际操作步骤

数据库 SQL Server
我们今天主要是和大家一起讨论的是正确建立SQL Server 2005邮件的实际操作流程,以及在实际操作中值得我们大家注意的事项的描述。

以下的文章主要描述的是正确建立SQL Server 2005邮件的实际操作步骤,我们大家都知道数据库邮件(Database Mail)是 SQL Server 2005数据库引擎中***增的一项比较简单实用的功能。

Database Mail代替了SQL Mail,它使用一个简单SQL Server 2005邮件传输协议(SMTP)服务器,而不是SQL Mail所要求的MAPI账号来发送电子邮件。

这允许你的组织发送带附件和查询结果的电子邮件,附加查询结果,以及格式化HTML电子邮件。你还可以用它设定许多其它配置,而不需要你拥有一台Exchange服务器或配置任何类型的MAPI工作区。

使用Database Mail的好处

 

除完全以SMTP为基础外,Database Mail还具有许多其它优点:

 

它在数据库引擎以外运行,因此对数据库引擎的压力最小。

 

它支持群集,完全支持群集环境。

它的用户资料(Profile)允许使用冗余SMTP服务器。(我将在本文后部分详细讨论这一点。)

它允许你以参数的形式向存储过程发送查询文本,存储过程将执行查询并在电子邮件中发送结果。

消息通过一个Service Broker队列异步传送,因此你在发送电子SQL Server 2005邮件时不必等待回应。

它为电子邮件发送提供多重安全保护,如一个控制附件扩展名的过滤器和一个附件大小管理器。

建立和使用Database Mail

在建立一个Database Mail解决方案前,你需要进行一些规划工作。首先,你必须具有一台有效的SMTP服务器来传送电子邮件。如果你没有SMTP服务器,请参阅微软知识库文章308161了解建立SMTP服务器的相关信息。如果你无法确定组织是否拥有SMTP服务器,询问你的网络管理员获得机器名称或服务器的IP地址。你的网络管理员可能需要对服务器进行配置,以便SQL Server能够发送电子邮件。

 

在Database Mail中,账户(Account)保存数据库引擎用来发送电子SQL Server 2005邮件消息的信息。一个账户只为一台电子邮件服务器保存信息,如账户名、电子邮件地址、回复电子邮件地址、服务器名称或IP地址,以及一些可选的安全设置。

 

要发送一封Database Mail电子邮件,必须使用一个用户资料(Profile)。用户资料为一个或几个账户设立。这种用户资料-账户设置非常有用。它允许你将几个账户和一个用户资料联系起来,这意味着你可以将几台电子邮件服务器和一个用户资料联系起来。

 

因此,当你试图发送一封电子邮件时,系统会尝试用户资料中的每个账户,直到消息被成功发送出去。如果一台或几台SMTP服务器出现故障,这种设置就十分有用。它还允许你开发发送电子邮件的应用程序代码,而不必担心针对不同的环境修改Profile名称。你可以在开发和生产环境中使用相同的Profile名称,唯一的差别在于用户资料中包含的账户有所不同。

 

该是时候了解如何建立一个Database Mail账户了。在我们的例子中,我假设你正坐在一台你具有系统管理员访问权限的开发机器前。如果你没有系统管理员权限,你需要成为msdb数据库DatabaseMailUserRole的一员。

 

下面的脚本建立一些我在整个实例中都要用到的变量。注意:整个脚本将在msdb数据库中运行,Database Mail对象就保存在其中。

  1. USE msdb GO DECLARE @ProfileName VARCHAR(255) DECLARE  
  2. @AccountName VARCHAR(255) DECLARE @SMTPAddress VARCHAR(255) DECLARE  
  3. @EmailAddressVARCHAR(128) DECLARE @DisplayUser VARCHAR(128)  

这里我建立了ProfileName、AccountName、STMP服务器名称以及显示在电子SQL Server 2005邮件From(邮件来自)框中的地址。

  1. SET @ProfileName = 'DBMailProfile';  
  2. SET @AccountName = 'DBMailAccount';  
  3. SET @SMTPAddress = 'mail.yoursmtpserver.com';   
  4. SET @EmailAddress = 'DBMail@yoursmtpserver.com';   
  5. SET @DisplayUser = 'The Mail Man';  

下面的的脚本完成一些清理工作,以便如果我再次运行脚本,就不必担心出现错误。

IF EXISTS ( SELECT * FROM msdb.dbo.sysmail_profileaccount pa JOIN msdb.dbo.sysmail_profile p>下面的脚本给系统增加账户(Account)、用户资料(Profile)和账户-用户资料(Account-Profile)关系。

  1. EXECUTE msdb.dbo.sysmail_add_account_sp @account_name =  
  2. @AccountName, @email_address = @EmailAddress,   
  3. @display_name = @DisplayUser, @mailserver_name =  
  4. @SMTPAddress EXECUTE msdb.dbo.sysmail_add_profile_sp   
  5. @profile_name = @ProfileName EXECUTE msdb.dbo.sysmail_add_profileaccount_sp  
  6. @profile_name = @ProfileName, @account_name =   
  7. @AccountName, @sequence_number = 1 ;  

现在一切都已经准备妥当,我将发送一封测试电子邮件。

  1. EXEC msdb.dbo.sp_send_dbmail @recipients=N'chapman.tim@gmail.com',   
  2. @body'Test Email Body', @subject = 'Test Email Subject', @profile_name = @ProfileName  

要检查消息是否发送成功,我可以对sysmail_allitems系统视图执行一次查询。

  1. SELECT * FROM sysmail_allitems 

以上的相关内容就是对建立SQL Server 2005数据库邮件的介绍,望你能有所收获。

 

【编辑推荐】

  1. SQL Server备份文件中对现存数据库的导入
  2. 用SQL Server DBCC 避免堵塞的实际操作步骤
  3. 改善SQL Server安全规划的6步骤
  4. SQL Server 2000文件损坏的修复方案
  5. SQL Server 2000优化SELECT 语句的方案介绍
责任编辑:佚名 来源: 比特网
相关推荐

2010-07-21 15:22:07

2010-07-14 17:56:13

SQL Server

2010-07-16 11:10:52

SQL server

2010-07-12 09:52:24

删除 SQL Serv

2010-07-12 10:13:44

SQL Server表

2010-07-02 11:10:56

SQL Server

2010-07-23 14:26:37

SQL Server存

2010-09-13 09:53:42

IT服务管理

2010-07-21 09:28:34

SQL Server

2010-04-16 17:17:31

Oracle访问

2010-06-28 09:28:32

SQL Server

2010-07-07 11:03:21

SQL Server索

2010-06-17 10:50:53

SQL Server数

2010-06-09 11:40:32

MySQL SQL 语

2010-03-12 15:29:19

Pythonexe

2010-07-22 14:38:17

2010-06-28 12:39:14

SQL Server数

2010-07-23 09:25:50

SQL Server导

2010-06-30 17:56:06

2010-06-28 12:27:35

SQL Server
点赞
收藏

51CTO技术栈公众号