Create your first CLR Trigger for SQL Server 2008 using C#.
What are CLR Triggers?
- CLR triggers are trigger based on CLR.
- CLR integration is new in SQL Server 2008. It allows for the database objects (such as a trigger) to be coded in .NET.
- Objects that have heavy computation or that require a reference to an object outside SQL are coded in the CLR.
- We can code both DDL and DML triggers by using a supported CLR language like C#.
Steps to Create a CLR trigger
Step 1: Create the CLR class. We code the CLR class module with a reference to the namespace required to compile CLR database objects.
Add the following references:
- using Microsoft.SqlServer.Server;
- using System.Data.SqlTypes;
So the following is the complete code for the class:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Data.Sql;
- using System.Data.SqlClient;
- using Microsoft.SqlServer.Server;
- using System.Data.SqlTypes;
- using System.Text.RegularExpressions;
- namespace CLRTrigger
- {
- public class CLRTrigger
- {
- public static void showinserted()
- {
- SqlTriggerContext triggContext = SqlContext.TriggerContext;
- SqlConnection conn = new SqlConnection(" context connection =true ");
- conn.Open();
- SqlCommand sqlComm = conn.CreateCommand();
- SqlPipe sqlP = SqlContext.Pipe;
- SqlDataReader dr;
- sqlComm.CommandText = "SELECT pub_id, pub_name from inserted";
- dr = sqlComm.ExecuteReader();
- while (dr.Read())
- sqlP.Send((string)dr[0] + "," + (string)dr[1]);
- }
-
- }
- }
Step 2: Compile this class and in the BIN folder of project we will get CLRTrigger.dll generated. After compiling for CLRTrigger.dll, we need to load the assembly into SQL Server.
Step 3: Now we will use T-SQL command to execute to create the assembly for CLRTrigger.dll. For that we will use CREATE ASSEMBLY in SQL Server.
- CREATE ASSEMBLY triggertest
- FROM 'C:\CLRTrigger\CLRTrigger.dll'
- WITH PERMISSION_SET = SAFE
Step 4: The final step is to create the trigger that references the assembly. Now we will write the following T-SQL commands to add a trigger on the publishers table in the Pubs database.
- CREATE TRIGGER tri_Publishes_clr
- ON publishers
- FOR INSERT
- AS
- EXTERNAL NAME triggertest.CLRTrigger.showinserted
If you get a compatibility-related error message, run the following command to set compatibility.
- ALTER DATABASE pubs
- SET COMPATIBILITY_LEVEL = 100
Step 5: Enable CLR Stored procedure on SQL Server. For this run the following code:
- EXEC sp_configure 'show advanced options' , '1';
- reconfigure;
- EXEC sp_configure 'clr enabled' , '1' ;
- reconfigure;
-
- EXEC sp_configure 'show advanced options' , '0';
- reconfigure;
Step 6: Now we will run INSERT statement to the publishers table that fires the newly created CLR trigger.
- INSERT publishers(pub_id, pub_name) values ('9922','Vishal Nayan')
The trigger simply echoes the contents of the inserted table. The output from the trigger is based on the insertion above.
-----------------------------------------------------
9922,Vishal Nayan
(1 row(s) affected)
The line of code which is printing the query result is actually the following code written in a managed environment.
- while (dr.Read())
- sqlP.Send((string)dr[0] + "," + (string)dr[1]);
Conclusion
The tri_Publishes_clr trigger demonstrates the basic steps for creating a CLR trigger. The true power of CLR triggers lies in performing more complex calculations, string manipulations and things of this nature that can be done much more efficiently with CLR programming languages than they can in T-SQL.