Sql 查询邮件地址多行合并一行,再发送邮件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Sql 查询邮件地址多行合并一行,再发送邮件相关的知识,希望对你有一定的参考价值。

--创建测试表
use Fly
go
IF OBJECT_ID(‘test‘) IS NOT NULL
    DROP TABLE test
CREATE TABLE test(
    Id int IDENTITY(1,1) NOT NULL,
    Name varchar(50) NULL,
    Judge char(1) NULL,
    Mail varchar(50) NULL
)
GO

--插入测试数据
INSERT INTO test (
            Name ,Judge ,Mail) 
    SELECT ‘张三‘,‘Y‘,‘[email protected]‘ UNION ALL
    SELECT ‘李四‘,‘Y‘,‘[email protected]‘ UNION ALL
    SELECT ‘王五‘,‘N‘,‘[email protected]‘ 
GO

SELECT * FROM test

--查询多行合并
DECLARE 
    @Maliaddress varchar(8000)
set @Maliaddress = ‘‘‘‘ + STUFF((SELECT ‘;‘ + Mail FROM test WHERE Judge in (‘Y‘) FOR xml path(‘‘)),1,1,‘‘) + ‘‘‘‘  
select @Maliaddress as ‘MailAddress‘ 

exec msdb.dbo.sp_send_dbmail
@profile_name = ‘Fly_Huang‘,                
@recipients = @Maliaddress,     
@subject = ‘Test电子邮件的主题‘,                       
@body = ‘Test电子邮件的正文‘,                              
@body_format = ‘html

以上是关于Sql 查询邮件地址多行合并一行,再发送邮件的主要内容,如果未能解决你的问题,请参考以下文章

从SQL服务器为数据集的每一行发送电子邮件。

sql 将查询结果为多行一列合并为一行一列

用Python实现邮件发送Hive明细数据

mysql 将查询结果 定期 发送邮件,这个功能mysql可以实现么?

SQL 查询以查找具有相同列值的多行

oMail - 将更改的合并字段从数据库表单添加到 vba 代码