如何在sp_send_dbmail中的@query parameter中传递多个查询
例如:
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语句之后停止。
发布于 2012-10-11 23:16:17
当您执行select count(*) from TableA时,您不会将值保存在某个地方,它只执行并返回查询的结果。这就是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方面有所保留。但由于我不知道你是如何使用它的,它现在应该可以工作了。
https://stackoverflow.com/questions/12842052
复制相似问题