我有一个关于使用 sp_send_dbmail 将查询结果作为附件发送的两部分问题。
问题 1:只会打开基本的 .txt 文件。.pdf 或 .jpg 等任何其他格式已损坏。
问题 2:尝试发送多个附件时,我收到一个文件,其中所有文件名都粘在一起。
我正在运行 SQL Server 2005,并且我有一个存储上传文档的表:
CREATE TABLE [dbo].[EmailAttachment](
[EmailAttachmentID] [int] IDENTITY(1,1) NOT NULL,
[MassEmailID] [int] NULL, -- foreign key
[FileData] [varbinary](max) NOT NULL,
[FileName] [varchar](100) NOT NULL,
[MimeType] [varchar](100) NOT NULL
我还有一个带有标准电子邮件内容的 MassEmail 表。这是 SQL 发送邮件脚本。为简洁起见,我排除了声明语句。
while ( (select count(MassEmailID) from MassEmail where status = 20 )>0)
begin
select @MassEmailID = Min(MassEmailID) from MassEmail where status = 20
select @Subject = [Subject] from MassEmail where MassEmailID = @MassEmailID
select @Body = Body from MassEmail where MassEmailID = @MassEmailID
set @query = 'set nocount on; select cast(FileData as varchar(max)) from Mydatabase.dbo.EmailAttachment where MassEmailID = '+ CAST(@MassEmailID as varchar(100))
select @filename = ''
select @filename = COALESCE(@filename+ ',', '') +FileName from EmailAttachment where MassEmailID = @MassEmailID
exec msdb.dbo.sp_send_dbmail
@profile_name = 'MASS_EMAIL',
@recipients = 'me@myemail.com',
@subject = @Subject,
@body =@Body,
@body_format ='HTML',
@query = @query,
@query_attachment_filename = @filename,
@attach_query_result_as_file = 1,
@query_result_separator = '; ',
@query_no_truncate = 1,
@query_result_header = 0;
update MassEmailset status= 30,SendDate = GetDate() where MassEmailID = @MassEmailID
end
我能够成功地从数据库中读取文件,所以我知道二进制数据没有损坏。
.txt 文件仅在我将 FilaData 转换为 varchar 时读取。但显然原始标题丢失了。还值得注意的是,附件文件的大小与原始文件不同。这很可能也是由于编码不当造成的。所以我希望有一种方法可以使用存储的 mimetype 创建文件头,或者以某种方式在二进制数据中包含文件头?
我对最后几个参数的值也没有信心,而且我知道 coalesce 不太正确,因为它在第一个文件名前加上逗号。但是几乎不可能找到好的文档。请帮忙!