Sunday, October 31, 2010

Create View

create view VIEW_first

AS

SELECT E.name,C.fname FROM emp E,copy1 C


select * from VIEW_first

VIEWS IN SQL SERVER


A view is a virtual table that consists of columns from one or more tables. Though it is similar to a table, it is stored in the database. It is a query stored as an object. Hence, a view is an object that derives its data from one or more tables. These tables are referred to as base or underlying tables.
Once you have defined a view, you can reference it like any other table in a database.
A view serves as a security mechanism. This ensures that users are able to retrieve and modify only the data seen by them. Users cannot see or access the remaining data in the underlying tables. A view also serves as a mechanism to simplify query execution. Complex queries can be stored in the form as a view, and data from the view can be extracted using simple queries.

Example

Consider the Publishers table below. If you want users to see only two columns in the table, you can create a view called vwPublishers that will refer to the Publishers table and the two columns required. You can grant Permissions to users to use the view and revoke Permissions from the base Publishers table. This way, users will be able to view only the two columns referred to by the view. They will not be able to query on the Publishers table.
Publishers
Publd
PubName
City
State
Country
036
New Books
Boson
MA
USA
077
Binnet
Wasngton
DC
USA
138
Algodata 
Berkey
CA
USA
162
Five Lakes Publishing
Chicgo
IL
USA
VW Publishers
Publd
PubName
073
New Moon Books
087
Binnet & Hardly
138
Algodata
162
Five Lakes
Views ensure the security of data by restricting access to the following data:
  • Specific rows of the tables.
  • Specific columns of the tables.
  • Specific rows and columns of the tables.
  • Rows fetched by using joins.
  • Statistical summary of data in a given tables.
  • Subsets of another view or a subset of views and tables.
Some common examples of views are:
  • A subset of rows or columns of a base table.
  • A union of two or more tables.
  • A join of two or more tables.
  • A statistical summary of base tables.
  • A subset of another view, or some combination of views and base table.

TRIGGER ON DATA UPDATION


create trigger afterupdate
on emp
AFTER UPDATE
as
begin
declare @name varchar(50)
declare @fname varchar(50)
declare @ser numeric(18,0)
select @name=name from inserted
select @fname=fname from inserted
select @ser=ser_num     from inserted
update copy set name=@name  ,fname=@fname where ser_num=@ser
PRINT 'AFTER TRIGGER EXECUTED SUCESSFULLY'
end
GO

insert into emp(name,fname)values('abc','xyz');

update emp set name='ajay', fname='sh.sp sharma' where ser_num='7'

select * from copy





TRIGGER ON AFTER INSERTION OF DATA



create trigger afterinsert_trigger1
on emp
AFTER INSERT
as
begin
declare @name varchar(50)
declare @fname varchar(50)
select @name=name from inserted
select @fname=fname from inserted
select @ser=ser_num     from inserted
insert into copy(name,fname,ser_num)values(@name,@fname,@ser)
PRINT 'AFTER TRIGGER EXECUTED SUCESSFULLY'
end
GO

insert into emp(name,fname)values('xzz','xxaa');

 AFTER TRIGGER EXECUTED SUCESSFULLY

(1 row(s) affected)
AFTER TRIGGER EXECUTED SUCESSFULLY

(1 row(s) affected)


select * from copy




 

Types of triggers in sql server with example



Types of Triggers

Triggers are of 3 types in SQL Server 2005:
1.   DMLTriggers
. AFTER         Triggers
.INSTEAD       OF      Triggers
2. DDL Triggers
3. CLR  Triggers


Note:DDL and CLR Triggers cannot work in SQL Server 2000
DML Trigger:-These Trigger is fired only when INSERT, UPDATE, and DELETE Statement occurs in table.

Explanation   on        DML    Trigger:
Let us create a Table and insert some records in that Table.
1)After Triggers:
After Triggers can be created in 3 ways.
1) After         INSERT
2) After         UPDATE
3) After         DELETE

1) creating After INSERT Trigger:-
Syntax:create trigger           triggername             on        tablename     AFTER INSERT
As
[SQL    Statement/PRINT   Command]
GO

Eg:
create trigger           afterinsert_trigger             on        emp    AFTER INSERT
as
PRINT 'AFTER TRIGGER EXECUTED SUCESSFULLY'
GO

When you execute the afterinsert_trigger it give
s message as 'The Command(s) created successfully'
You can see the is trigger is created.


Now insert one record in a emp table. You can see the trigger will be fired automatically when the row is inserted in a table successfully.


Creating AFTER UPDATE TRIGGER:-

create trigger afterupdate_trigger
on emp
AFTER UPDATE
as
PRINT 'AFTER UPDATE TRIGGER EXECUTED SUCESSFULLY'
GO
 
Creating AFTER DELETE TRIGGER:
Create trigger afterdelete_trigger
On emp
AFTER DELETE
as
PRINT 'AFTER DELETE TRIGGER EXECUTED SUCESSFULLY'
GO
Instead Of Update Trigger
Creating INSTEAD OF UPDATE TRIGGER:-

create trigger insteadofupdate_trigger
on emp

INSTEAD OF UPDATE
as
PRINT 'INSTEAD OF UPDATE TRIGGER EXECUTED SUCESSFULLY'
GO

               

 
Instead of Delete Trigger
Creating INSTEAD OF DELETE TRIGGER:-

create trigger insteadofdelete_trigger
on emp
INSTEAD OF DELETE
as
PRINT 'INSTEAD OF DELETE TRIGGER EXECUTED SUCESSFULLY'
GO