Kolumna rozdzielana przecinkami SQL na ograniczniku

Oto funkcja podziału, którą można zastosować jakodbo.Split('sf,we,fs,we',','), gdy zmieniam ciąg na nazwę kolumny, nie działa, na przykładdbo.Split(table.columnName,',').

Select * from dbo.Split('[email protected]','@')

to działa, ale

Select * from dbo.Split((Select Email from Users),'@') 

ma komunikat o błędzie:

Msg 102, Level 15, State 1, Line 1
Incorrect syntax near '('.
Msg 102, Level 15, State 1, Line 1
Incorrect syntax near ','

Funkcja jest tutaj:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER FUNCTION [dbo].[Split] (@String varchar(8000), @Delimiter char(1))     
   returns @temptable TABLE (items varchar(8000))       
   as       
   begin       
       declare @idx int       
        declare @slice varchar(8000)       

        select @idx = 1       
            if len(@String)<1 or @String is null  return       

       while @idx!= 0       
       begin       
           set @idx = charindex(@Delimiter,@String)       
           if @idx!=0       
               set @slice = left(@String,@idx - 1)       
           else       
              set @slice = @String       

           if(len(@slice)>0)  
               insert into @temptable(Items) values(@slice)       

           set @String = right(@String,len(@String) - @idx)       
           if len(@String) = 0 break       
       end   
   return       
   end

o których mowa w:SQL 2005 Podziel rozdzieloną przecinkami kolumnę na ograniczniku

Albo ktoś może dać mi podobną funkcję, która może podzielić jedną kolumnę na dwie

questionAnswers(1)

yourAnswerToTheQuestion