Sql sp_send_dbmail错误
如何在Sql sp_send_dbmail错误,sql,tsql,sql-server-2005,Sql,Tsql,Sql Server 2005,如何在sp\u send\u dbmail中的@query参数中传递多个查询 例如: select count(*) from TableA IF count(*)/ @@rowcount = 0 Exec sp_send_dbmail @profile_name = xx, @recipients = 'xx@abc.com',@subject = 'Test', @body= ' No rows'; IF count(*)/ @@rowcount > 0 Exec sp_send_
sp\u send\u dbmail
中的@query参数中传递多个查询
例如:
select count(*) from TableA
IF count(*)/ @@rowcount = 0
Exec sp_send_dbmail @profile_name = xx, @recipients = 'xx@abc.com',@subject = 'Test', @body= ' No rows';
IF count(*)/ @@rowcount > 0
Exec sp_send_dbmail @profile_name = xx, @recipients = 'xx@abc.com',@subject = 'Test',
@body= ' xx rows';
我没有收到任何错误消息,但它在第一个select语句后停止。当您从表A执行select count(*)时,您没有将值保留在某个位置,它只执行并返回查询结果。这就是为什么if
语句没有触发的原因。你可以这样做:
DECLARE @c AS int
SET @c = (select count(*) from TableA)
IF @c = 0
Exec sp_send_dbmail @profile_name = xx, @recipients = 'xx@abc.com',@subject = 'Test', @body= 'No rows';
IF @c > 0
Exec sp_send_dbmail @profile_name = xx, @recipients = 'xx@abc.com',@subject = 'Test',
@body= ' xx rows';
虽然我对将这种逻辑放在SQL端有些保留。但因为我不知道你是如何使用它的,所以现在应该可以用了