从Excel的vba中通过ADO执行msdb.dbo.sp_send_dbmail

时间:2015-02-02 17:50:33

标签: sql-server vba excel-vba ado excel

我正在尝试运行以下内容:

Sub sendMailViaADO()

Dim cmdStoredFunct As ADODB.Command
Dim r As ADODB.Recordset

Dim strConn As String
strConn = _
    "PROVIDER=SQLOLEDB.1;" & _
    "P-----D=xxxxx;" & _
    "PERSIST SECURITY INFO=True;" & _
    "USER ID=yyyyyy;" & _
    "INITIAL CATALOG=xxxxx;" & _
    "DATA SOURCE=xxxxx;" & _
    "USE PROCEDURE FOR PREPARE=1;" & _
    "AUTO TRANSLATE=True;" & _
    "CONNECT TIMEOUT=0;" & _
    "COMMAND TIMEMOUT=0" & _
    "PACKET SIZE=4096;" & _
    "USE ENCRYPTION FOR DATA=False;" & _
    "TAG WITH COLUMN COLLATION WHEN POSSIBLE=False"

Set c= New ADODB.Connection
c.ConnectionString = strConn
c.CommandTimeout = 0
c.Open

Set cmdStoredFunct = New ADODB.Command
Set cmdStoredFunct.ActiveConnection = c
Set r = New ADODB.Recordset

With cmdStoredFunct
    .CommandText = "msdb..sp_send_dbmail"
    .CommandText = adCmdStoredProc

    .Parameters.Append .CreateParameter("@recipients", adVarWChar, adParamInput, 50, "me@me.co.uk;")
    .Parameters.Append .CreateParameter("@subject", adVarWChar, adParamInput, 50, "xxx")
    .Parameters.Append .CreateParameter("@body", adVarWChar, adParamInput, 50, "yyy")

    Set r = .Execute
End With

'>>>
'>>>is there another way like the following ?
'Dim sTemp1
'sTemp1 = "{call msdb.dbo.sp_send_dbmail('me@me.co.uk', 'xxx', 'yyy')}"
'>>>


If Not (cmdStoredFunct Is Nothing) Then
    Set cmdStoredFunct.ActiveConnection = Nothing
    Set cmdStoredFunct = Nothing
End If
If Not (c Is Nothing) Then
    If (c.State And 1) = 1 Then c.Close
End If


End Sub

执行命令Set r = .Execute出错,显示以下消息:

enter image description here

在我看来,它发现存储过程正常,但它正在使用的字符串导致了这个神秘的异常。

我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

作为示例,如果您想避免使用命令对象:

Dim sSQL as String

sSQL = 
    "EXEC msdb.dbo.sp_send_dbmail  " & _
      @recipients='me@me.co.uk'," & _
      @subject='xxx'," & _
      @body='yyy'"

Call r.Open(sSQL,c)

人们会对SQL注入感到愤怒,但这是你最不担心的事情。