0

次のコードがあります。

DECLARE

@ATTACH_FILE nvarchar (max),
@SQL varchar (max);

/* ============================================================== */  

-- add files to attach
    SET @ATTACH_FILE = N'\\C:\attach\file.txt';

SET @SQL = 'exec msdb.dbo.sp_send_dbmail
@profile_name = ''ProfileMail'',
@recipients = ''my@mail.ru'',
@reply_to = ''my@mail.ru'',
@subject = ''subject mail'',
@body = ''body mail'',
@file_attachments='' '+ @ATTACH_FILE +' '' ';

-- send mail
    EXEC(@SQL);

UPDは 2 つのスラッシュを削除します SET @ATTACH_FILE = N'C:\attach\file.txt'; - エラーが続く

次のエラーが表示されます: 添付ファイル \C:\attach\file.txt が無効です (ファイルは SQL サーバーにあります)。
何が問題なのかわかりません。

4

3 に答える 3

1

エラーは添付ファイルのアドレスについて'//'ですextra space今すぐ機能します。

declare @attach_file nvarchar(100),@sql varchar(max)
   SET @ATTACH_FILE = N'C:\attach\file.txt';

SET @SQL = 'exec msdb.dbo.sp_send_dbmail
@profile_name = ''ProfileMail'',
@recipients = ''my@mail.ru'',
@reply_to = ''my@mail.ru'',
@subject = ''subject mail'',
@body = ''body mail'',
@file_attachments='+char(39)+@ATTACH_FILE+char(39);

-- send mail
   Exec(@sql)
于 2013-11-13T07:21:20.150 に答える
0

指定したとおり、そのファイルは SQL サーバーにあります。以下のクエリを使用して、ファイルの正確なアドレスを見つけます。

SELECT name, physical_name AS current_file_location
   FROM sys.master_files

メールの添付ファイルにアドレスを使用します。

于 2013-11-13T07:28:36.707 に答える