SQL Server Performance Tuning

Are Triggers Making Your SQL Server Slow?

Mark Varnas
No comments

What are SQL Server triggers?

They are a particular type of stored procedure that automatically runs when an event occurs in the database.

Why should you care about them?

The delete, update, and insert operations against theses objects incur extra costs, which affects performance.

Massive bulks and recursive triggers can cause severe performance.

How can I find the triggers?

Triggers on a table

  1. Open SSMS, expand the Databases and choose your database.
  2. Click on the target table and Expand the Triggers to list all items.

Triggers on a database

  1. Open SSMS, expand the Databases and choose your database.
  2. Click on Programmability and
  3. Choose Database Triggers to list all items.

How to identify the triggers

You can use the query below to identify all the triggers in your database tables:

SELECT  table_name = OBJECT_NAME(parent_object_id)
	,        trigger_name = name
	,        trigger_owner = USER_NAME(schema_id)
	,        OBJECTPROPERTY(object_id, 'ExecIsUpdateTrigger') AS isupdate
	,        OBJECTPROPERTY(object_id, 'ExecIsDeleteTrigger') AS isdelete
	,        OBJECTPROPERTY(object_id, 'ExecIsInsertTrigger') AS isinsert
	,        OBJECTPROPERTY(object_id, 'ExecIsAfterTrigger') AS isafter
	,        OBJECTPROPERTY(object_id, 'ExecIsInsteadOfTrigger') AS isinsteadof
	,        CASE OBJECTPROPERTY(object_id, 'ExecIsTriggerDisabled')          
		WHEN 1
			THEN 'Disabled'          
		ELSE 'Enabled'        
		END AS STATUS FROM    sys.objects WHERE   type = 'TR'
ORDER BY OBJECT_NAME(parent_object_id)

How to fix them?

Triggers are not always bad, but they must be used wisely.

  1. Look into triggers with the highest resource consumption.
  2. See if they can be replaced by another method.
  3. If not, see if the trigger code can be optimized.

More information

Article by
Mark Varnas
Founder | CEO | SQL Veteran
Hey, I'm Mark, one of the guys behind Red9. I make a living performance tuning SQL Servers and making them more stable. I channel my SQL into our SQL Managed Services, SQL Consulting and our internal database products.

Managed SQL Server services, consulting, and emergency support from expert DBAs to improve performance, predictability, and cost.

Get started with Red9 today.

Contact us

Discover More

Discover what clients are saying about Red9

Red9 has incredible expertise both in SQL migration and performance tuning.

The biggest benefit has been performance gains and tuning associated with migrating to AWS and a newer version of SQL Server with Always On clustering. Red9 was integral to this process. The deep knowledge of MSSQL and combined experience of Red9 have been a huge asset during a difficult migration. Red9 found inefficient indexes and performance bottlenecks that improved latency by over 400%.

Rich Staats 5 stars
Rich Staats
Cloud Engineer
MetalToad

Always willing to go an extra mile

Working with Red9 DBAs has been a pleasure. They are great team players and have an expert knowledge of SQL Server database administration. And are always willing to go the extra mile to get the project done.
5 stars
Evelyn A.
Sr. Database Administrator

Boosts server health and efficiency for enhanced customer satisfaction

Since adding Red9 to the reporting and DataWarehousing team, Red9 has done a good job coming up to speed on our environments and helping ensure we continue to meet our customer's needs. Red9 has taken ownership of our servers ensuring they remain healthy by monitoring and tuning inefficient queries.
5 stars
Andrew F.
Datawarehousing Manager
See more testimonials