Skip to main content

Coalesce function

Coalesce function returns the first non-null value among the arguments.

Syntax:

Coalesce (expression [,..n])

Here is example using Coalesce function

Example 1

DECLARE @Str1 varchar(10),@str2 varchar(20),@Str3 varchar(20)

SET @Str2='Sql' , @Str3='Server'

SELECT COALESCE(@Str1,@str2,@Str3) As [Coalesce]


In above example @Str2 value is ‘Sql’ , @str3 value is ‘Server’  and @str1 values is Null because it not assigned any value .

Output:

It return’s “Sql” because Coalesce function return’s first non null value.








Example 2:

Coalesce in select statement.

IF OBJECT_ID('Employee','U') IS NOT NULL
DROP TABLE Employee


CREATE TABLE Employee
(
  ID INT IDENTITY(1,1) PRIMARY KEY ,
  NAME VARCHAR(20),
  SALARY INT
)

INSERT INTO Employee  (NAME,SALARY) VALUES ('Rakesh',5000),(NULL,6000),('Naresh',7000) ,(NULL,8000)


SELECT * FROM Employee










In above Query Result ID 2, 4 of Name Column is null.   We have to replace Name Column null value to some other value (“Madhu”) using select statement.

SELECT ID,COALESCE(NAME,'Madhu') AS Name,SALARY FROM Employee

Output:









Example 3:

Coalesce in where condition.

DECLARE @Lod_ID int =null

SET @Lod_ID =3

SELECT * FROM Employee where ID= COALESCE(@Lod_ID,ID)
Output:

It only select ID value 3 row .because of in above @Lod_ID variable is set to 3 values . Coalesce funtion returns first non-null value baecuse it’s selects only 3 of ID colums rows only.  





Example 4:

DECLARE @Lod_ID int =null

SELECT * FROM Employee where ID= COALESCE(@Lod_ID,ID)

In above example if we are not set any value to @Lod_ID variable . we are get all row from Employee table .

Comments

Post a Comment

Popular posts from this blog

SP_MSForeachtable

Some times we need to query on the all the tables in one data base single statement. We use SP_MSForeachtable this is known as undocumented stored procedures . These all are system stored procedures. These stored procedures is place in Master database. NOTE: Please do not run all these queries in Production environment Example: create database UnDocumentedStoredProcedure use UnDocumentedStoredProcedure create table Emp ( ID int identity ( 1 , 1 ), Name varchar ( 50 ), Salary int ) insert into Emp ( Name , Salary ) values ( 'rakesh' , 8000 ),( 'raju' , 9000 ) create table Dept ( ID int identity ( 1 , 1 ), DeptName varchar ( 100 ) ) insert into Dept ( DeptName ) values ( 'CSE' ),( 'IT' ) We are created new database and also created some table with some dummy data. Select all tables data: exec sp_MSForeachtable 'select * from ?...

SET ROWCOUNT

Stop the processing after the number of rows has been affected. Example: Step-1: Create the Table and insert some sample data. CREATE TABLE STUDENT ( ID INT IDENTITY ( 1 , 1 ) PRIMARY KEY , STUDENTNAME VARCHAR ( 100 ) NOT NULL , LIVINGLOCATION VARCHAR ( 100 ) NULL ) INSERT INTO STUDENT ( STUDENTNAME , LIVINGLOCATION ) SELECT 'Rakesh' , 'Hyderabad' UNION ALL SELECT 'Raju' , 'Delhi' UNION ALL SELECT 'Madhu' , 'Hyderabad' UNION ALL SELECT 'Naresh' ,NULL UNION ALL SELECT 'Venaktesh' , 'Chennai' In above Insert Statement we inserted 5 sample records. Step-2: Using SET ROWCOUT SET ROWCOUNT 3 ; SELECT * FROM STUDENT ORDER BY ID DESC It will affected 3 rows after that processing has been stopped. Step-2: Using SET ROWCOUT 0 SET ROWCOUNT 0 ; SELECT * FROM STUDENT ORDER BY ID DESC ...