Click here to Skip to main content
15,917,176 members
Please Sign up or sign in to vote.
0.00/5 (No votes)
See more:
In below Stored procedure I am trying to avoid NULL and "" value but not succeed.
----------------------------------------

What I have tried:

SQL
CREATE PROCEDURE GET_DISTINCT_FIELD_VALUE 

  @FIELD_NAME nvarchar(50),
  @TABLE_NAME nvarchar(59)

AS

BEGIN

declare @q nvarchar(max)


 set @q = ' select distinct '+ @FIELD_NAME+' FIELD_VALUE from ' + @TABLE_NAME + ' where '+@FIELD_NAME +' <>'' order by '+@FIELD_NAME +' asc'


exec (@q)


END
Posted
Updated 13-Dec-17 16:53pm
v2

see updated below

SQL
CREATE PROCEDURE GET_DISTINCT_FIELD_VALUE 
 
  @FIELD_NAME nvarchar(50),
  @TABLE_NAME nvarchar(59)
 
AS
 
BEGIN
 
declare @q nvarchar(max)
 

 set @q = ' select distinct '+ @FIELD_NAME+' FIELD_VALUE from ' + @TABLE_NAME + ' where len('+@FIELD_NAME +') <> 0 and ' + +@FIELD_NAME + ' Is not null order by '+@FIELD_NAME +' asc'
 

exec (@q)
 

END
 
Share this answer
 
v2
Comments
Richard Deeming 13-Dec-17 9:53am    
You had an extra single quote before the "0", which broke the query. I've removed it for you. :)
Member 13574079 14-Dec-17 0:05am    
Thanks a lot
CREATE PROCEDURE GET_DISTINCT_FIELD_VALUE 
 (
 
  @FIELD_NAME nvarchar(50),
  @TABLE_NAME nvarchar(59)
 )
AS
 
BEGIN
 
declare @q nvarchar(max)
 

 set @q = ' select distinct '+ @FIELD_NAME+' FIELD_VALUE from ' + @TABLE_NAME + '
             where '+@FIELD_NAME +'<>'' ''  AND '+@FIELD_NAME +'IS NOT NULL 
             order by '+@FIELD_NAME;
 

EXEC(@q)
 

END
 
Share this answer
 
Comments
Member 13574079 14-Dec-17 0:06am    
Working, Thanks a lot....:)

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



CodeProject, 20 Bay Street, 11th Floor Toronto, Ontario, Canada M5J 2N8 +1 (416) 849-8900