Tuesday, 8 August 2017

Trigger in sql server

A trigger is a special kind of stored procedure that automatically executes when an event occurs in the database server. DML triggers execute when a user tries to modify data through a data manipulation language (DML) event. DML events are INSERTING, UPDATE, or DELETE statements on a table or view.

Type of Trigger

Ø  DML trigger
Ø  DDL trigger
Ø  Log on trigger
Ø  CLR Triggers

DML Trigger

There are two type of DML trigger. It is faired automatically in response to DML (Insert, Update and delete) event.
Ø   After Trigger (For trigger)
Ø  Instead of Triggers

After Triggers

These triggers are executed after an action such as Insert, Update or Delete is performed. For example  If we insert record/row in a table then the trigger associated with the insert event on this table will fire only after the row passes all the checks, such as primary key, rules, and constraints. If the record/row insertion fails, SQL Server will not fire the After Trigger.
Let see the example
I have a table
CREATE TABLE [EMP](
                [ID] [int] IDENTITY(1,1) NOT NULL,
                [Name] [varchar](50) NULL,
                [empAdd] [varchar](50) NULL,
                [Mobile] [varchar](10) NULL
           )
Inserting some records some


Now I am creating an audit table which stores the information of insert, update and delete.
create table tblAuditEmp
  (
   ID INT IDENTITY (1,1),
   Audit_Desc varchar(1000)
   )

This table has all audit info.
Now I am going to create an insert trigger on EMP tale.
create  trigger trg_Emp_insert on EMP
for insert
as
begin
select * from inserted
end

Trigger has been created. Now I am inserting


 Inserted table
INSERTED logical table will hold the rows which are inserted by the INSERT and UPDATE statement.
Now I am writing the script to insert record in audit table.
http://bageshkumarbagi-msbi.blogspot.in/2017/08/inserted-and-deleted-logical-tables-in.html


Create trigger trg_Emp_insert on EMP
for insert
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from inserted i;
select @emp_name=i.Name from inserted i;
select @emp_empadd =i.empAdd from inserted i;
select @emp_Mob = i.Mobile from inserted i;
SET @audit_action='Inserted Record ,trg_Emp_insert.';
BEGIN

 SET @str = 'Employee ID '+ cast(@emp_id as varchar) + ' is inserted on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END


There is no record in audit table


Now I am inserting a record in emp table.
Record inserted


Now I am seeing the Audit table.



Trigger for Update
Now I am creating a new trigger for update.

Create trigger trg_Emp_update on EMP
for Update
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from inserted i;
select @emp_name=i.Name from inserted i;
select @emp_empadd =i.empAdd from inserted i;
select @emp_Mob = i.Mobile from inserted i;
SET @audit_action='Updated Record ,trg_Emp_update.';
BEGIN

 SET @str = 'Employee ID '+ CAST( @emp_id as VARCHAR) + ' is updated on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END

Updating the record.


Now see the records in audit table.


Trigger for Delete
When we deleting the record it will execute and insert record in audit table.
Create trigger trg_Emp_Delete on EMP
for delete
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from deleted i;
select @emp_name=i.Name from deleted i;
select @emp_empadd =i.empAdd from deleted i;
select @emp_Mob = i.Mobile from deleted i;
SET @audit_action='deleted Record ,trg_Emp_update.';
BEGIN

 SET @str = 'Employee ID '+ CAST( @emp_id as VARCHAR) + ' is deleted on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END

Now I am deleting the record from emp table.


 Deleted table
DELETED logical table will hold the rows which are deleted from the trigger table (i.e. the table on which the trigger is defined) by the DELETE.

Read: INSERTED and DELETED Logical Tables in Sql Server


Instead of Triggers

These triggers are executed instead of any of the Insert, Update or Delete operations. For example, let’s say we write an Instead of Trigger for Delete operation, and then whenever a Delete is performed the Trigger will be executed first and if the Trigger deletes record then only the record will be deleted.
Delete Trigger
Create trigger trg_Emp_Delete_Instead_of on EMP
Instead of delete
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from deleted i;
select @emp_name=i.Name from deleted i;
select @emp_empadd =i.empAdd from deleted i;
select @emp_Mob = i.Mobile from deleted i;
SET @audit_action='deleted Record ,trg_Emp_update.';
BEGIN

 SET @str = 'Employee ID '+ CAST( @emp_id as VARCHAR) + ' is deleted on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END


Trigger update
Create trigger trg_Emp_update_Instead_of on EMP
Instead of Update
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from inserted i;
select @emp_name=i.Name from inserted i;
select @emp_empadd =i.empAdd from inserted i;
select @emp_Mob = i.Mobile from inserted i;
SET @audit_action='Updated Record ,trg_Emp_update.';
BEGIN

 SET @str = 'Employee ID '+ CAST( @emp_id as VARCHAR) + ' is updated on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END

Trigger Insert
Create trigger trg_Emp_insert_Instead_of on EMP
Instead of insert
AS
declare @emp_id int, @emp_name varchar(55), @emp_empadd varchar(100),
        @emp_Mob varchar(100), @audit_action varchar(100),@str VARCHAR(1000);
select @emp_id=i.ID from inserted i;
select @emp_name=i.Name from inserted i;
select @emp_empadd =i.empAdd from inserted i;
select @emp_Mob = i.Mobile from inserted i;
SET @audit_action='Inserted Record ,trg_Emp_insert.';
BEGIN

 SET @str = 'Employee ID '+ cast(@emp_id as varchar) + ' is inserted on '+ cast(getdate() as varchar) +' Employee Name : ' + @emp_name
                                                + 'Employee Add : ' + @emp_empadd + ' Mobile : '+ @emp_Mob + '   ' + @audit_action;

Insert into tblAuditEmp (Audit_Desc) values (@str);
END



Popular Posts