Friday, September 5, 2008

Reorder Rearrange comma separated list using MySQL or MS Sql Server

So far i have seen on the web for solution to reorder or rearrange a comma separated varchar/string value. but did not find a solution where u could do it in a simple way without using temporary tables, cursors or table variables in MS Sql Server or MySql.

this a sample for Mysql

set @newVal='7749,7750,7751,7741,7742' ;
set @P_vcQueryMain:=concat('select group_concat(Expid order by expId) from (Select ''',REPLACE(@newVal,',',''' as ExpId union Select '''),''' as ExpId order by ExpId) ExpVals into @newVal ;');
PREPARE stmt FROM @P_vcQueryMain;
EXECUTE stmt ;
DEALLOCATE PREPARE stmt;
select @newVal;


Input value : [7749,7750,7751,7741,7742]
Output value : [7741,7742,7749,7750,7751]


set @newVal='banana,apple,cake,cream,apple pie' ;
set @P_vcQueryMain:=concat('select group_concat(Expid order by expId) from (Select ''',REPLACE(@newVal,',',''' as ExpId union Select '''),''' as ExpId order by ExpId) ExpVals into @newVal ;');
PREPARE stmt FROM @P_vcQueryMain;
EXECUTE stmt ;
DEALLOCATE PREPARE stmt;
select @newVal;

Input value : [banana,apple,cake,cream,apple pie]
Output value : [apple,apple pie,banana,cake,cream]

here @newVal contains the values to be reordered and the same variable returns the correctly reordered string back


this a sample for MsSql Server

declare @newVal varchar(max);
declare @P_vcQueryMain varchar(max);
set @newVal='7749,7751,7741,7750,7742' ;
set @P_vcQueryMain='declare @RetVal varchar(max);; select @RetVal =coalesce(@RetVal + '','' ,'''') + Expid from (Select ''' + REPLACE(@newVal,',',''' as ExpId union Select ''')+ ''' as ExpId) ExpVals order by ExpId; select @RetVal;';
exec(@P_vcQueryMain);

Input value : [7749,7750,7751,7741,7742]
Output value : [7741,7742,7749,7750,7751]

declare @newVal varchar(max);
declare @P_vcQueryMain varchar(max);
set @newVal='banana,apple,cake,cream,apple pie' ;
set @P_vcQueryMain='declare @RetVal varchar(max);; select @RetVal =coalesce(@RetVal + '','' ,'''') + Expid from (Select ''' + REPLACE(@newVal,',',''' as ExpId union Select ''')+ ''' as ExpId) ExpVals order by ExpId; select @RetVal;';
exec(@P_vcQueryMain);

Input value : [banana,apple,cake,cream,apple pie]
Output value : [apple,apple pie,banana,cake,cream]

this solution reduces the query cost, as the string is reordered in just one sql statement rather than using tables or cursors which are memory consuming.

any better suggestion welcome, pls write a comment if u find the post helpfull.

.blog

Thursday, August 28, 2008

First Posting

Its on the 28th of august 2008 that i have finally createad a blog for myself, pushed by the guys and gals of my team @ personiva, pune.