how to find substring between 3rd and 4th comma

How to write a function which returns substring between commas.

example :
    @TempString = "25,134,315,124,248,15,"

select myfunction(@TempString, 3, ',')
should return : 315

select myfunction(@TempString, 4, ',')
should return : 124
Bharat GuruAsked:
Who is Participating?
 
devlab2012Connect With a Mentor Commented:
Here is the code for function that you need:


CREATE FUNCTION myfunction
(
@TempString varchar(50),
@position int,
@separator char(1)
) RETURNS varchar(50)
AS
BEGIN

declare @cp int
set @cp = 1
while (@cp < @position) 
begin
	set @TempString = substring(@TempString, charindex(@separator,@TempString) + 1,len(@TempString))
	set @cp = @cp + 1
end
set @TempString = substring(@TempString, 0, charindex(@separator, @TempString))
return @TempString
END

Open in new window

0
 
Philippe DamervalSenior Analyst ProgrammerCommented:
Hi,
This pseudocode should help you


function getStringAtCommaNumber (StringParm, commaPosition)
  Define Stringvar as string variable
  Define dynamic array of strings
  while (position of comma in string > 0)
     add (left part of string up to first comma position) to array
     Reassign whatever is right of the same position to stringvar
  end while
  if stringvar not empty then add stringvar to array
  return element of array at position commaposition - 1
end

The question is just 100 points after all :) I hope this helps. You will find all the reference information you need by looking up SQL server string functions (position, left, right, etc)

Thx

Philippe
0
 
Bharat GuruAuthor Commented:
I just updated following statement and it worked perfectly
set @cp = 0

Thannks
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.