En primer lugar, cree una función (usando CTE, expresión de tabla común elimina la necesidad de una tabla temporal)
create function dbo.SplitString
(
@str nvarchar(4000),
@separator char(1)
)
returns table
AS
return (
with tokens(p, a, b) AS (
select
1,
1,
charindex(@separator, @str)
union all
select
p + 1,
b + 1,
charindex(@separator, @str, b + 1)
from tokens
where b > 0
)
select
p-1 zeroBasedOccurance,
substring(
@str,
a,
case when b > 0 then b-a ELSE 4000 end)
AS s
from tokens
)
GO
A continuación, utilizarlo como cualquier tabla (o modificar para que se ajuste dentro de su procedimiento almacenado existente) como este.
select s
from dbo.SplitString('Hello John Smith', ' ')
where zeroBasedOccurance=1
Actualización
Versión anterior sería un fracaso para la cadena de entrada de más de 4000 caracteres. Esta versión se hace cargo de la limitación:
create function dbo.SplitString
(
@str nvarchar(max),
@separator char(1)
)
returns table
AS
return (
with tokens(p, a, b) AS (
select
cast(1 as bigint),
cast(1 as bigint),
charindex(@separator, @str)
union all
select
p + 1,
b + 1,
charindex(@separator, @str, b + 1)
from tokens
where b > 0
)
select
p-1 ItemIndex,
substring(
@str,
a,
case when b > 0 then b-a ELSE LEN(@str) end)
AS Item
from tokens
);
GO
Uso sigue siendo el mismo.