Skip to main content

Merge Statement Part-1

 --Create Source_Student
 if object_id('Source_Student') is null
 create table Source_Student(id int identity(1,1) ,Name varchar(20)Marks int)
               
--Insert Some Sample Data to Source_Student
  insert Source_Student (Name,Marks) values('Rakesh',500)
  insert Source_Student (Name,Marks) values('Raju',400)
               
--Create Target_Student
 if object_id('Target_Student') is null
 create table Target_Student(id int ,Name varchar(20), Marks int)
               
--Insert Some Sample Data to Target_Student
  insert Target_Student (id,Name,Marks) values(1,'Rakesh',600)
  insert Target_Student (id,Name,Marks) values(3,'Nani',700)
               
  --Select Two Tables Data
   select * from Source_Student
   select * from Target_Student

In the Source table Id -1 record need to update marks column. Id-2 record need to insert in the Target Column. In the Target column Id-3 record need delete from Target column.
  --Run Merge Satement
  merge into Target_Student as trg
   using  Source_Student  as src 
   on trg.Name=Src.Name
    when matched then update
              set trg.Name=src.Name, trg.Marks=src.Marks
    when not matched then insert (id,Name,Marks)
                                    values(src.id,src.Name,src.Marks)
   when not matched by source then delete;

Select * from Target_Student
     





Comments

Post a Comment

Popular posts from this blog

Rank Functions in SQL SERVER

1 . ROW_NUMBER () OVER ( [PARTITION BY CLAUSE] < ORDER BY CLUASE >): Returns the sequantial number of a row within the a partition of result set at 1 for the first row of the each partition. 2. RANK () OVER ( [PARTITION BY CLAUSE] < ORDER BY CLUASE >): Returns rank for rows within the partition of result set. 3. DENSE_RANK () OVER ( [PARTITION BY CLAUSE] < ORDER BY CLUASE >): Returns rank for rows within the partition of result set.With out any gaps in the ranking. 4. NTILE ( INTEGER_EXPRESSION ) OVER ( [PARTITION BY CLAUSE] < ORDER BY CLUASE >): Distributes the rows in an ordered partition into a specified number of groups. Examples: --create Employee table create table Employee (                 EmpId int identity ( 1 , 1 ) primary key ,              ...

Difference between LEN and DATALENGTH

LEN: LEN function returns the number of characters in a variable .it also removes the trailing spaces and then then return the length. Example-1: DECLARE @Name VARCHAR ( 20 )= 'rakesh' SELECT LEN ( @Name ) as [len] Output: Example-2: DECLARE @Name VARCHAR ( 20 )= 'rakesh ' SELECT LEN ( @Name ) as [len] Output: When we observe above variable assigned 'rakesh ' string after that added 3 spaces . Len function removes trailing spaces not leading spaces. DATALENGTH : DATALENG function returns the number of bytes occupy in a variable .it also considered the spaces also. Example-1: DECLARE @Name VARCHAR ( 20 )= 'rakesh' SELECT DATALENGTH ( @Name ) as [DataLength] Output: Example-2: DECLARE @Name VARCHAR ( 20 )= ' rakesh ' SELECT DATALENGTH ( @Name ) as [DataLength] Output: In above example before ' r ' and after ...