关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL Server »正确建立SQL Server 2005邮件的实际操作步骤

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

    2010-07-05 10:15:00 出处:ITJS
    分享

    以下的文章主要描述的是正确建立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对象就保存在其中。

    USE msdb GO DECLARE @ProfileName VARCHAR(255) DECLARE  @AccountName VARCHAR(255) DECLARE @SMTPAddress VARCHAR(255) DECLARE  @EmailAddressVARCHAR(128) DECLARE @DisplayUser VARCHAR(128)  

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

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

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

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

    EXECUTE msdb.dbo.sysmail_add_account_sp @account_name =  @AccountName, @email_address = @EmailAddress,   @display_name = @DisplayUser, @mailserver_name =  @SMTPAddress EXECUTE msdb.dbo.sysmail_add_profile_sp   @profile_name = @ProfileName EXECUTE msdb.dbo.sysmail_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  

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

    SELECT * FROM sysmail_allitems 

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

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    抖音安全与信任开放日:揭秘推荐算法,告别单一标签依赖

    ultraedit编辑器打开文件时,总是提示是否转换为DOS格式,如何关闭?

    Cornell大神Kleinberg的经典教材《算法设计》是最好入门的算法教材

    从 Microsoft 下载中心安装 Windows 7 SP1 和 Windows Server 2008 R2 SP1 之前要执行的步骤

    Llama 2基于UCloud UK8S的创新应用

    火山引擎DataTester:如何使用A/B测试优化全域营销效果

    腾讯云、移动云继阿里云降价后宣布大幅度降价

    字节跳动数据平台论文被ICDE2023国际顶会收录,将通过火山引擎开放相关成果

    这个话题被围观超10000次,火山引擎VeDI如此解答

    误删库怎么办?火山引擎DataLeap“3招”守护数据安全

    IT头条

    平替CUDA!摩尔线程发布MUSA 4性能分析工具

    00:43

    三起案件揭开侵犯个人信息犯罪的黑灰产业链

    13:59

    百度三年开放2.1万实习岗,全力培育AI领域未来领袖

    00:36

    工信部:一季度,电信业务总量同比增长7.7%,业务收入累计完成4469亿元

    23:42

    Gartner:2024年全球半导体营收6559亿美元,AI助力英伟达首登榜首

    18:04

    技术热点

    iOS 8 中如何集成 Touch ID 功能

    windows7系统中鼠标滑轮键(中键)的快捷应用

    MySQL数据库的23个特别注意的安全事项

    Kruskal 最小生成树算法

    Ubuntu 14.10上安装新的字体图文教程

    Ubuntu14更新后无法进入系统卡在光标界面解怎么办?

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。