HiveBrain v1.2.0
Get Started
← Back to all entries
patternsqlMajor

Should I add SET NOCOUNT ON to all my triggers?

Submitted by: @import:stackexchange-dba··
0
Viewed 0 times
allnocountshouldtriggerssetadd

Problem

It is fairly common knowledge that you should have

SET NOCOUNT ON


by default when creating new stored procedures.

Microsoft has changed the default template to include this in 2012. I thought this should be the same for triggers, yet it is not included in the template.

Is this intentional or just an oversight?

Solution

Personally, I would recommend it - I can't think of a reason not to, unless you have a trigger where you specifically want to call out the fact that it's doing additional work behind the scenes.

I wrote a short article about things to watch for when writing triggers, and this is one of them:

http://dave.brittens.org/blog/writing-well-behaved-triggers.html

tl;dr version:

  • Cut the chatter. Use NOCOUNT.



  • Make sure your trigger can handle multiple rows.



  • Prevent unbounded trigger cascading and recursion.



  • Avoid horrible performance of the INSERTED and DELETED virtual tables.

Context

StackExchange Database Administrators Q#21148, answer score: 24

Revisions (0)

No revisions yet.