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删除两个斜杠 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

替换这个

SET @ATTACH_FILE = N'\\C:\attach\file.txt';

有了这个

SET @ATTACH_FILE = N'C:\attach\file.txt';
于 2013-11-13T06:51:31.903 回答
0

正如您指定的文件在 Sql server.Find 使用下面的查询文件的确切地址。

SELECT name, physical_name AS current_file_location
   FROM sys.master_files

并使用邮件附件中的地址。

于 2013-11-13T07:28:36.707 回答