,@description = null -- 邮件账户描述
,@mailserver_name = 'smtp.qq.com' -- 邮件服务器地址
,@mailserver_type = 'SMTP' -- 邮件协议
,@port = 25 -- 邮件服务器端口
,@username = '980095349@qq.com' -- 用户名
,@password = 'xxxxxx' -- 密码
,@use_default_credentials = 0 -- 是否使用默认凭证,0为否,1为是
,@enable_ssl = 1 -- 是否启用 ssl 加密,0为否,1为是
,@account_id = null -- 输出参数,返回创建的邮件账户的ID
PS:如果使用的是QQ邮箱,记得要把参数 @enable_ssl 的值设置为 1 。不然后面会报服务器错误,这个错误搞了我好久,最后终于找到原因了。
步骤三:
if exists(SELECT * FROM msdb..sysmail_profile where NAME = N'SendEmailProfile') --判断名为 SendEmailProfile 的邮件配置文件是否存在
begin
exec msdb..sysmail_delete_profile_sp @profile_name = 'SendEmailProfile' --删除名为 SendEmailProfile 的邮件配置文件
end
exec msdb..sysmail_add_profile_sp -- 添加邮件配置文件
@profile_name = 'SendEmailProfile', -- 配置文件名称
@description = '数据库发送邮件配置文件', -- 配置文件描述
@profile_id = NULL -- 输出参数,返回创建的邮件配置文件的ID步骤四:
-- 邮件账户和邮件配置文件相关联
exec msdb..sysmail_add_profileaccount_sp
@profile_name = 'SendEmailProfile', -- 邮件配置文件名称
@account_name = 'test', -- 邮件账户名称
@sequence_number = 1 -- account 在 profile 中的顺序,一个配置文件可以有多个不同的邮件账户好了,到这里 sql 发送邮件的配置就基本结束了。下面创建一个触发器实现用户注册成功后,发送邮件给用户。
首先创建一个表:
-- 创建一个表
create table T_User
(
UserID int not null identity(1,1) primary key,
UserNo nvarchar(64) not null unique,
UserPwd nvarchar(128) not null ,
UserMail nvarchar(128) null
)
go然后创建一个 insert 类型的 after 触发器:
create trigger NewUser_Send_Mail
on T_User
after insert
as
declare @UserNo nvarchar(64)
declare @title nvarchar(64)
declare @content nvarchar(320)
declare @mailUrl nvarchar(128)
declare @count int
select @count=COUNT() from inserted
select @UserNo=UserNo,@mailUrl=UserMail from inserted
if(@count>0)
begin
set @title='注册成功通知'
set @content='欢迎您'+@UserNo+'!您已成功注册!通知邮件,请勿回复!'










