当前位置:首页 » 编程语言 » sql发邮件

sql发邮件

发布时间: 2023-08-01 18:13:52

① 如何通过sqlserver数据库发送邮件

Database Mail代替了SQL Mail,它使用一个简单邮件传输协议(SMTP)服务器,而不是SQL Mail所要求的MAPI账号来发送电子邮件。 这允许你的组织发送带附件和查询结果的电子邮件,附加查询结果,以及格式化HTML电子邮件。你还可以用它设定许多其它配置,而不需要你拥有一台Exchange服务器或配置任何类型的MAPI工作区。 使用Database Mail的好处除完全以SMTP为基础外,Database Mail还具有许多其它优点:
它在数据库引擎以外运行,因此对数据库引擎的压力最小。
它支持群集,完全支持群集环境。
它的用户资料(Profile)允许使用冗余SMTP服务器。(我将在本文后部分详细讨论这一点。)
它允许你以参数的形式向存储过程发送查询文本,存储过程将执行查询并在电子邮件中发送结果。
消息通过一个Service Broker队列异步传送,因此你在发送电子邮件时不必等待回应。 它为电子邮件发送提供多重安全保护,如一个控制附件扩展名的过滤器和一个附件大小管理器。 建立和使用Database Mail在建立一个Database Mail解决方案前,你需要进行一些规划工作。首先,你必须具有一台有效的SMTP服务器来传送电子邮件。如果你没有SMTP服务器,请参阅微软知识库文章308161了解建立SMTP服务器的相关信息。如果你无法确定组织是否拥有SMTP服务器,询问你的网络管理员获得机器名称或服务器的IP地址。你的网络管理员可能需要对服务器进行配置,以便SQL Server能够发送电子邮件。 在Database Mail中,账户(Account)保存数据库引擎用来发送电子邮件消息的信息。一个账户只为一台电子邮件服务器保存信息,如账户名、电子邮件地址、回复电子邮件地址、服务器名称或IP地址,以及一些可选的安全设置。 要发送一封Database Mail电子邮件,必须使用一个用户资料(Profile)。用户资料为一个或几个账户设立。这种用户资料-账户设置非常有用。它允许你将几个账户和一个用户资料联系起来,这意味着你可以将几台电子邮件服务器和一个用户资料联系起来。 因此,当你试图发送一封电子邮件时,系统会尝试用户资料中的每个账户,直到消息被成功发送出去。如果一台或几台SMTP服务器出现故障,这种设置就十分有用。它还允许你开发发送电子邮件的应用程序代码,而不必担心针对不同的环境修改Profile名称。你可以在开发和生产环境中使用相同的Profile名称,唯一的差别在于用户资料中包含的账户有所不同。 该是时候了解如何建立一个Database Mail账户了。在我们的例子中,我假设你正坐在一台你具有系统管理员访问权限的开发机器前。如果你没有系统管理员权限,你需要成为msdb数据库DatabaseMailUserRole的一员。 下面的脚本建立一些我在整个实例中都要用到的变量。

② sql server 2005 如何用存储过程发送邮件

A.
使用简单过程
以下存储过程将从视图中返回所有雇员(提供姓和名)、职务以及部门名称。此存储过程不使用任何参数。
复制
USE
AdventureWorks;
GO
IF
OBJECT_ID
(
'HumanResources.uspGetAllEmployees',
'P'
)
IS
NOT
NULL
DROP
PROCEDURE
HumanResources.uspGetAllEmployees;
GO
CREATE
PROCEDURE
HumanResources.uspGetAllEmployees
AS
SET
NOCOUNT
ON;
SELECT
LastName,
FirstName,
JobTitle,
Department
FROM
HumanResources.vEmployeeDepartment;
GO
uspGetEmployees
存储过程可通过以下方式执行:
复制
EXECUTE
HumanResources.uspGetAllEmployees;
GO
--
Or
EXEC
HumanResources.uspGetAllEmployees;
GO
--
Or,
if
this
procere
is
the
first
statement
within
a
batch:
HumanResources.uspGetAllEmployees;
B.
使用带有参数的简单过程
下面的存储过程只从视图中返回指定的雇员(提供名和姓)及其职务和部门名称。此存储过程接受与传递的参数精确匹配的值。
复制
USE
AdventureWorks;
GO
IF
OBJECT_ID
(
'HumanResources.uspGetEmployees',
'P'
)
IS
NOT
NULL
DROP
PROCEDURE
HumanResources.uspGetEmployees;
GO
CREATE
PROCEDURE
HumanResources.uspGetEmployees
@LastName
nvarchar(50),
@FirstName
nvarchar(50)
AS
SET
NOCOUNT
ON;
SELECT
FirstName,
LastName,
JobTitle,
Department
FROM
HumanResources.vEmployeeDepartment
WHERE
FirstName
=
@FirstName
AND
LastName
=
@LastName;
GO
uspGetEmployees
存储过程可通过以下方式执行:
复制
EXECUTE
HumanResources.uspGetEmployees
N'Ackerman',
N'Pilar';
--
Or
EXEC
HumanResources.uspGetEmployees
@LastName
=
N'Ackerman',
@FirstName
=
N'Pilar';
GO
--
Or
EXECUTE
HumanResources.uspGetEmployees
@FirstName
=
N'Pilar',
@LastName
=
N'Ackerman';
GO
--
Or,
if
this
procere
is
the
first
statement
within
a
batch:
HumanResources.uspGetEmployees
N'Ackerman',
N'Pilar';
C.
使用带有通配符参数的简单过程
以下存储过程只从视图中返回指定的一些雇员(提供名和姓)及其职务和部门名称。此存储过程模式与所传递的参数相匹配;或者,如果未提供参数,则使用预设的默认值(以字母
D
打头的姓)。
复制
USE
AdventureWorks;
GO
IF
OBJECT_ID
(
'HumanResources.uspGetEmployees2',
'P'
)
IS
NOT
NULL
DROP
PROCEDURE
HumanResources.uspGetEmployees2;
GO
CREATE
PROCEDURE
HumanResources.uspGetEmployees2
@LastName
nvarchar(50)
=
N'D%',
@FirstName
nvarchar(50)
=
N'%'
AS
SET
NOCOUNT
ON;
SELECT
FirstName,
LastName,
JobTitle,
Department
FROM
HumanResources.vEmployeeDepartment
WHERE
FirstName
LIKE
@FirstName
AND
LastName
LIKE
@LastName;
GO
uspGetEmployees2
存储过程可使用多种组合执行。下面只显示了几个组合:
复制
EXECUTE
HumanResources.uspGetEmployees2;
--
Or
EXECUTE
HumanResources.uspGetEmployees2
N'Wi%';
--
Or
EXECUTE
HumanResources.uspGetEmployees2
@FirstName
=
N'%';
--
Or
EXECUTE
HumanResources.uspGetEmployees2
N'[CK]ars[OE]n';
--
Or
EXECUTE
HumanResources.uspGetEmployees2
N'Hesse',
N'Stefen';
--
Or
EXECUTE
HumanResources.uspGetEmployees2
N'H%',
N'S%';
D.
使用
OUTPUT
参数
以下示例将创建
uspGetList
存储过程。此过程将返回价格不超过指定数值的产品的列表。此示例显示如何使用多个
SELECT
语句和多个
OUTPUT
参数。OUTPUT
参数允许外部过程、批处理或多条
Transact-SQL
语句在过程执行期间访问设置的某个值。
复制
USE
AdventureWorks;
GO
IF
OBJECT_ID
(
'Proction.uspGetList',
'P'
)
IS
NOT
NULL
DROP
PROCEDURE
Proction.uspGetList;
GO
CREATE
PROCEDURE
Proction.uspGetList
@Proct
varchar(40)
,
@MaxPrice
money
,
@ComparePrice
money
OUTPUT
,
@ListPrice
money
OUT
AS
SET
NOCOUNT
ON;
SELECT
p.[Name]
AS
Proct,
p.ListPrice
AS
'List
Price'
FROM
Proction.Proct
AS
p
JOIN
Proction.ProctSubcategory
AS
s
ON
p.ProctSubcategoryID
=
s.ProctSubcategoryID
WHERE
s.[Name]
LIKE
@Proct
AND
p.ListPrice

热点内容
国开在线密码是多少 发布:2025-02-07 04:29:13 浏览:147
服务器可以用来干什么 发布:2025-02-07 04:28:39 浏览:946
资源为什么可以配置 发布:2025-02-07 04:27:38 浏览:989
数字电路存储器实验 发布:2025-02-07 04:13:29 浏览:813
在什么地方查qq密码 发布:2025-02-07 04:01:51 浏览:11
买二手笔记本电脑看哪些配置 发布:2025-02-07 04:01:48 浏览:309
我的世界里面什么服务器是建造的 发布:2025-02-07 03:51:48 浏览:190
不能连接到数据库 发布:2025-02-07 03:47:00 浏览:46
安卓手机如何设置翻屏动画 发布:2025-02-07 03:46:18 浏览:595
利基型存储器什么意思 发布:2025-02-07 03:43:58 浏览:557