5

sp_send_dbmail を使用してクエリ結果を添付ファイルとして送信することに関して、2 つの部分からなる質問があります。

問題 1:基本的な .txt ファイルしか開かない。.pdf や .jpg などの他の形式は破損しています。

問題 2:複数の添付ファイルを送信しようとすると、すべてのファイル名がくっついた 1 つのファイルを受け取ります。

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 Send Mail スクリプトは次のとおりです。簡潔にするために、declare ステートメントを除外しました。

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 にキャストしたときにのみ読み取られます。しかし、元のヘッダーが失われていることは明らかです。また、添付ファイルのサイズが元のファイルと異なることにも注意してください。これは、不適切なエンコーディングが原因である可能性が最も高いです。だから、保存されたMIMEタイプを使用してファイルヘッダーを作成する方法、またはバイナリデータにファイルヘッダーを含める方法があることを願っていますか?

また、最後のいくつかのパラメーターの値に自信がありません。最初のファイル名の前にコンマが追加されるため、coalesce が正しくないこともわかっています。しかし、適切なドキュメントを見つけることはほとんど不可能です。助けてください!

4

2 に答える 2

8

SQL からバイナリ データを直接送信できるとは思えません。この同じ問題について話している投稿がいくつかあります。Microsoftのドキュメントによると、クエリへのテキスト リターンはテキスト ファイルとしてフォーマットされています。Binary は 16 進数としてフォーマットされます。あなたが指摘したように、テキストドキュメントではないファイルは破損します。

ただし、最初にBCPを使用してバイナリデータをファイルシステムにエクスポートし、次にsendmailで利用できる従来のファイル添付方法を介してインポートすることで、あなたがやろうとしていることを達成できると思います.

だから、このようなもの。(概念のみ - テストされていないコード)

DECLARE @OutputFileAndPath VarChar(500) = '\\Log_Files\MyFile.pdf ' 
DECLARE @sql VarChar(8000)

SELECT @sql = 'BCP "SELECT MyFile FROM [dbo].[MyTable] 
    WHERE PrimaryKey = 12345" queryout ' + @OutputFileAndPath +
        ' -S MyServer\MyInstance -T -fC:\Documents.fmt'

/* you could use a generic format file that would cover most formats */

EXEC xp_cmdshell @sql, NO_OUTPUT;

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


    exec msdb.dbo.sp_send_dbmail    
        @profile_name = 'MASS_EMAIL',
        @recipients = 'me@myemail.com',
        @subject = @Subject,
        @body =@Body,
        @body_format ='HTML',
        @file_attachments = @OutputFileAndPath /* i.e. \\Log_Files\MyFile.pdf */

    update MassEmailset status= 30,SendDate = GetDate() where MassEmailID = @MassEmailID
end     
于 2012-09-14T21:11:26.190 に答える