Introduction
In this article, we will see what is DDL trigger and how to create one. We will also see how to store the audit data when a DML event occurs.
What is a DML trigger?
DML triggers run when a user tries to modify data through a data manipulation language (DML) event. DML events are INSERT, UPDATE, or DELETE statements. DML triggers can be used to enforce business rules and data integrity. DML trigger uses two special tables.
- The Inserted table
- The Deleted table
SQL Server automatically creates and manages these tables. It can be used to capture details of the data modifications and to set conditions for DML trigger actions.
The inserted table stores copies of the affected rows during INSERT and UPDATE statements. While executing the insert or update query, new rows are added to both the inserted table and the trigger table. The rows in the inserted table are copies of the new rows in the trigger table.
The deleted table stores copies of the affected rows during DELETE and UPDATE statements. During the execution of a DELETE or UPDATE statement, rows are deleted from the trigger table and transferred to the deleted table.
An update transaction is similar to a delete operation followed by an insert operation; the old rows are copied to the deleted table first, and then the new rows are copied to the trigger table and to the inserted table.
To create DML triggers use the following syntax,
- CREATE TRIGGER <Trigger_Name>
- ON <Table_Name>
- FOR INSERT|DELETE|UPDATE
- AS
- BEGIN
- <Trigger Body>
- END
We will see it practically, so first open SQL Server Management Studio and take a new worksheet and create a new database ‘sameer’, which is shown below.
Now create a table as 'employee', on which we will perform our DML operations.
- CREATE table employee (
- Emp_id INT IDENTITY(1,1) PRIMARY KEY,
- first_name varchar(20),
- last_name varchar(20),
- address_ varchar(20),
- );
- Create table Employee_Audit(
- Audit_Id INT IDENTITY(1,1) PRIMARY KEY,
- Audit_Data NVARCHAR(150)
- );
Next, insert a few records into the ‘employee’ table.
- insert into employee(first_name,last_name,address_) values
- ('Ashish','Randhir','Delhi'),
- ('Sameer','Gaikwad','Mumbai'),
- ('Satish','Rathore','Pune');
- select * from employee;
Now create an insert trigger on the ‘employee’ table as shown below.
- CREATE TRIGGER Trg_employee_Insert
- ON employee
- FOR INSERT
- AS
- BEGIN
- Declare @Audit_Id INT
- SELECT @Audit_Id= Emp_id from inserted
- INSERT into Employee_Audit(Audit_Data)
- VALUES('New employee with Eployee Id = ' + CAST(@Audit_Id AS NVARCHAR(50)) +' is added at ' + CAST(GETDATE() AS NVARCHAR(150)));
- END
- insert into employee(first_name,last_name,address_) values ('Rohit','Kadam','Nashik');
Now create an update trigger on the ‘employee’ table as shown below:
- CREATE TRIGGER Trg_employee_Update
- ON employee
- FOR UPDATE
- AS
- BEGIN
- Declare @Audit_Id INT,@first_name VARCHAR(25),@last_name VARCHAR(25),@address_ VARCHAR(25)
- SELECT @Audit_Id= Emp_id,@first_name= first_name,@last_name= last_name,@address_= address_ from inserted
- SELECT @Audit_Id= Emp_id,@first_name= first_name,@last_name= last_name,@address_= address_ from deleted
- INSERT into Employee_Audit(Audit_Data)
- VALUES('Record with Eployee Id = ' + CAST(@Audit_Id AS NVARCHAR(50)) +' is changed. Old Data was'+' First Name = ' + CAST(@first_name AS NVARCHAR(50))
- +', Last_Name = ' + CAST(@last_name AS NVARCHAR(50))+', address_ = ' + CAST(@address_ AS NVARCHAR(50)) +' at ' + CAST(GETDATE() AS NVARCHAR(150)));
- END
- Update employee set first_name='Rohini',last_name='Jagtap', address_='Nagpur'where Emp_id='2';
Now create a delete trigger on ‘employee’ table as shown below:
- CREATE TRIGGER Trg_employee_Delete
- ON employee
- FOR DELETE
- AS
- BEGIN
- Declare @Audit_Id INT
- SELECT @Audit_Id= Emp_id from deleted
- INSERT into Employee_Audit(Audit_Data)
- VALUES('Employee with Eployee Id = ' + CAST(@Audit_Id AS NVARCHAR(50)) +' is removed at ' + CAST(GETDATE() AS NVARCHAR(150)));
- END
- delete from employee where Emp_id='1';
0 Comments