Solved

Find Semi-Colon and split into temp table

Posted on 2008-09-30
5
684 Views
Last Modified: 2012-05-05
Hi, I have a table with two columns, ID, Recipients.

ID      Recipients
1      badboy@microsoft.com
2      rudeboy@microsoft.com;bill.gates@microsoft.co.uk
3      nutter@oracle.com;paul.jones@oracle.co.uk;diamondgeezer@mobiles.com
4      itsupport@spectrum.com

What I want to do is create a another temporary table that will have the same columns but I
want the output to appear like below

ID      Recipients
1      badboy@microsoft.com
2      rudeboy@microsoft.com
2      bill.gates@microsoft.co.uk
3      nutter@oracle.com
3      paul.jones@oracle.co.uk
3      diamondgeezer@mobiles.com
4      itsupport@spectrum.com

So what I want it to do is to go through the recipients column and find if there is
a semi-colon ';' if there is that will mean there is more that one email address so will need
to appear as one row in the temp table.

Thanks
0
Comment
Question by:sqlman08
5 Comments
 
LVL 60

Expert Comment

by:chapmandew
ID: 22605094
0
 
LVL 3

Expert Comment

by:DigitalSnorkle
ID: 22605161
0
 
LVL 6

Accepted Solution

by:
Ashok Kumar earned 500 total points
ID: 22605208
use can make use the below Function which will split based on a delimiter

create FUNCTION [dbo].[GetValuesFromList](
                    @List as Varchar(4000)
                    )

RETURNS @Table Table(Value Varchar(50))

AS    
Begin
     Declare @Sep          Varchar(1)
     Declare @Loc          Int
     Declare @Value     Varchar(100)
         
     
     If LTrim(RTrim(@List)) <> ''
     Begin
     
          Set @Sep = ';'  --- Mention the delimiter
          Set @List = @List + @Sep
         
          While PatIndex('%'+@Sep+'%',@List) <> 0
          Begin
               Set @Loc  =      PatIndex('%'+@Sep+'%',@List)
               Set @Value =     LTrim(Left(@List,@Loc-1))
               Set @List =      Stuff(@List,1,@Loc,'')

               
               
               Insert Into @Table(Value) Values (@Value)
     
          End --While
     End --If
     RETURN
End

go

declare @myArry varchar(1000)
select @myArry ='Oracle;Bill Gates;Windows;SQL 2008;ASP.NET'

select * from dbo.GetValuesFromList(@myArry)
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22605889
This will do it very fast without any looping, but requires a table of sequential numbers.

A table of sequential numbers is VERY useful in SQL Server not use for this.  If you have a table like that already, replace the table name below in place of vw_nums and the column name containing the number in place of n.
if object_id('[dbo].[fn_DelimitedToTable]') is not null
     drop function [dbo].[fn_DelimitedToTable]
go
create function [dbo].[fn_DelimitedToTable](@DelimitedString nvarchar(max), @Delimiter nvarchar(32))
returns @Values TABLE
     (ident         int not null identity primary key clustered
     ,thePosition   int not null
     ,theValue      nvarchar(max)
     )
as
begin
 
insert into @Values (thePosition,theValue)
		select n, substring(@delimiter + @DelimitedString + @delimiter, n + (datalength(@delimiter)/2), charindex(@delimiter, @delimiter + @DelimitedString + @delimiter, n + len(@delimiter)) - n - len(@delimiter)) as string_value
		from	dbo.vw_Nums
		where
			n <= (datalength(@delimiter + @DelimitedString + @delimiter)/2) - (datalength(@delimiter)/2)
			and substring(@delimiter + @DelimitedString + @delimiter, n, (datalength(@delimiter)/2)) = @delimiter
 
 
 
return
end

Open in new window

0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22605893
Usage:


select theValue from [dbo].[fn_DelimitedToTable]('a;b;c;d;e;f;g',';')

Open in new window

0

Featured Post

Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
convert varchar UTC to human datetime 1 38
SQL Query Task 11 42
How come this XML node is not read? 3 26
SQL 2014 missing dll from Bin? 3 31
Having an SQL database can be a big investment for a small company. Hardware, setup and of course, the price of software all add up to a big bill that some companies may not be able to absorb.  Luckily, there is a free version SQL Express, but does …
For both online and offline retail, the cross-channel business is the most recent pattern in the B2C trade space.
Via a live example, show how to shrink a transaction log file down to a reasonable size.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…

713 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question