提取每组两个不同字符串之间的每个字符串
Extract each string between each set of two different strings
如果我有例如字符串:
'x(abc),y(def),z(ghi)'
如何提取逗号分隔的字符串:
'abc,def,ghi'
或 table 个字符串:
'abc'
'def'
'ghi'
存在于两个字符串'('
和')'
之间?
它们以逗号分隔,但每个 'element' 可以是可变长度。
您可以像下面这样使用 charindex
:
declare @temp table
(val nvarchar(50))
insert into @temp values ('x(abc)')
insert into @temp values ('y(def)')
insert into @temp values ('z(ghi)')
SELECT
SUBSTRING(val,CHARINDEX('(', val) + 1,CHARINDEX(')', val) - CHARINDEX('(', val) - 1) as Val
from @temp
参考:SQL Select values inside parenthesis
编辑:如果它是一行包含括号内的许多值,则需要先根据逗号将其拆分。对于 SQL 2008,我多年来一直使用此 link 中指定的拆分功能,谢谢安迪:T-SQL split string
创建以下函数:
CREATE FUNCTION dbo.splitstring ( @stringToSplit VARCHAR(MAX) )
RETURNS
@returnList TABLE ([Name] [nvarchar] (500))
AS
BEGIN
DECLARE @name NVARCHAR(255)
DECLARE @pos INT
WHILE CHARINDEX(',', @stringToSplit) > 0
BEGIN
SELECT @pos = CHARINDEX(',', @stringToSplit)
SELECT @name = SUBSTRING(@stringToSplit, 1, @pos-1)
INSERT INTO @returnList
SELECT @name
SELECT @stringToSplit = SUBSTRING(@stringToSplit, @pos+1, LEN(@stringToSplit)-@pos)
END
INSERT INTO @returnList
SELECT @stringToSplit
RETURN
END
看看这个:SELECT * FROM dbo.splitstring('x(abc),y(def),z(ghi)')
这样,您可以根据逗号拆分数据并使用我提到的第一个 charindex 策略。
如果对 TVF 开放。作为 TVF,如果您的数据在 table.
中,则很容易在 CROSS APPLY
中使用
例子
Declare @S varchar(max) = 'x(abc),y(def),z(ghi)'
Select * from [dbo].[tvf-Str-Extract](@S,'(',')')
Returns
RetSeq RetPos RetVal
1 3 abc
2 10 def
3 17 ghi
感兴趣的函数
CREATE FUNCTION [dbo].[tvf-Str-Extract] (@String varchar(max),@Delimiter1 varchar(100),@Delimiter2 varchar(100))
Returns Table
As
Return (
with cte1(N) as (Select 1 From (values(1),(1),(1),(1),(1),(1),(1),(1),(1),(1)) N(N)),
cte2(N) as (Select Top (IsNull(DataLength(@String),0)) Row_Number() over (Order By (Select NULL)) From (Select N=1 From cte1 N1,cte1 N2,cte1 N3,cte1 N4,cte1 N5,cte1 N6) A ),
cte3(N) as (Select 1 Union All Select t.N+DataLength(@Delimiter1) From cte2 t Where Substring(@String,t.N,DataLength(@Delimiter1)) = @Delimiter1),
cte4(N,L) as (Select S.N,IsNull(NullIf(CharIndex(@Delimiter1,@String,s.N),0)-S.N,8000) From cte3 S)
Select RetSeq = Row_Number() over (Order By N)
,RetPos = N
,RetVal = left(RetVal,charindex(@Delimiter2,RetVal)-1)
From ( Select *,RetVal = Substring(@String, N, L) From cte4 ) A
Where charindex(@Delimiter2,RetVal)>1
)
/*
Max Length of String 1MM characters
Declare @String varchar(max) = 'Dear [[FirstName]] [[LastName]], ...'
Select * From [dbo].[tvf-Str-Extract] (@String,'[[',']]')
*/
如果我有例如字符串:
'x(abc),y(def),z(ghi)'
如何提取逗号分隔的字符串:
'abc,def,ghi'
或 table 个字符串:
'abc'
'def'
'ghi'
存在于两个字符串'('
和')'
之间?
它们以逗号分隔,但每个 'element' 可以是可变长度。
您可以像下面这样使用 charindex
:
declare @temp table
(val nvarchar(50))
insert into @temp values ('x(abc)')
insert into @temp values ('y(def)')
insert into @temp values ('z(ghi)')
SELECT
SUBSTRING(val,CHARINDEX('(', val) + 1,CHARINDEX(')', val) - CHARINDEX('(', val) - 1) as Val
from @temp
参考:SQL Select values inside parenthesis
编辑:如果它是一行包含括号内的许多值,则需要先根据逗号将其拆分。对于 SQL 2008,我多年来一直使用此 link 中指定的拆分功能,谢谢安迪:T-SQL split string
创建以下函数:
CREATE FUNCTION dbo.splitstring ( @stringToSplit VARCHAR(MAX) )
RETURNS
@returnList TABLE ([Name] [nvarchar] (500))
AS
BEGIN
DECLARE @name NVARCHAR(255)
DECLARE @pos INT
WHILE CHARINDEX(',', @stringToSplit) > 0
BEGIN
SELECT @pos = CHARINDEX(',', @stringToSplit)
SELECT @name = SUBSTRING(@stringToSplit, 1, @pos-1)
INSERT INTO @returnList
SELECT @name
SELECT @stringToSplit = SUBSTRING(@stringToSplit, @pos+1, LEN(@stringToSplit)-@pos)
END
INSERT INTO @returnList
SELECT @stringToSplit
RETURN
END
看看这个:SELECT * FROM dbo.splitstring('x(abc),y(def),z(ghi)')
这样,您可以根据逗号拆分数据并使用我提到的第一个 charindex 策略。
如果对 TVF 开放。作为 TVF,如果您的数据在 table.
中,则很容易在CROSS APPLY
中使用
例子
Declare @S varchar(max) = 'x(abc),y(def),z(ghi)'
Select * from [dbo].[tvf-Str-Extract](@S,'(',')')
Returns
RetSeq RetPos RetVal
1 3 abc
2 10 def
3 17 ghi
感兴趣的函数
CREATE FUNCTION [dbo].[tvf-Str-Extract] (@String varchar(max),@Delimiter1 varchar(100),@Delimiter2 varchar(100))
Returns Table
As
Return (
with cte1(N) as (Select 1 From (values(1),(1),(1),(1),(1),(1),(1),(1),(1),(1)) N(N)),
cte2(N) as (Select Top (IsNull(DataLength(@String),0)) Row_Number() over (Order By (Select NULL)) From (Select N=1 From cte1 N1,cte1 N2,cte1 N3,cte1 N4,cte1 N5,cte1 N6) A ),
cte3(N) as (Select 1 Union All Select t.N+DataLength(@Delimiter1) From cte2 t Where Substring(@String,t.N,DataLength(@Delimiter1)) = @Delimiter1),
cte4(N,L) as (Select S.N,IsNull(NullIf(CharIndex(@Delimiter1,@String,s.N),0)-S.N,8000) From cte3 S)
Select RetSeq = Row_Number() over (Order By N)
,RetPos = N
,RetVal = left(RetVal,charindex(@Delimiter2,RetVal)-1)
From ( Select *,RetVal = Substring(@String, N, L) From cte4 ) A
Where charindex(@Delimiter2,RetVal)>1
)
/*
Max Length of String 1MM characters
Declare @String varchar(max) = 'Dear [[FirstName]] [[LastName]], ...'
Select * From [dbo].[tvf-Str-Extract] (@String,'[[',']]')
*/