Sql 服务器提取字符串
Sql Server Extract String
我关注Table
DECLARE @TABLE TABLE (COL NVARCHAR(MAX))
insert @TABLE values
('[E=110][D=1]'),
('[E=110][D=NE]'),
('[E=110][D=U$]'),
('[E=110][D=FX]')
我正在尝试按照以下方式提取数据
COL || EXCEPTION_CODE || DATA
=========================================
[E=110][D=1] || 110 || 1
[E=110][D=NE] || 110 || NE
[E=110][D=U$] || 110 || U$
[E=110][D=FX] || 110 || FX
查看函数 SUBSTRING 和 CHARINDEX。
将它们一起使用,您应该能够提取它。
SUBSTRING(表达式,开始,长度)
CHARINDEX ( expressionToFind ,expressionToSearch [ , start_location ] )
例如:
SELECT SUBSTRING(COL,CHARINDEX('E=',COL)+2,CHARINDEX(']',COL) - CHARINDEX('E=',COL) - 2)
FROM @TABLE
将为您提供 EXCEPTION_CODE 列。
XML 比 charindex
更灵活。 replace
对于准备格式正确的 xml 非常有用。见代码。
;with dat(col, x) as (
select col, cast('<col'+replace(
replace(
replace(col,'=','="'),
']','" '),
'[',' ')+' />' as xml)
from @TABLE
)
select col, t.v.value('@E','int') Exception_code, t.v.value('@D','varchar(100)') [DATA]
from dat cross apply x.nodes('col') t(v)
并且结果如 OP 中所期望的那样。
我关注Table
DECLARE @TABLE TABLE (COL NVARCHAR(MAX))
insert @TABLE values
('[E=110][D=1]'),
('[E=110][D=NE]'),
('[E=110][D=U$]'),
('[E=110][D=FX]')
我正在尝试按照以下方式提取数据
COL || EXCEPTION_CODE || DATA
=========================================
[E=110][D=1] || 110 || 1
[E=110][D=NE] || 110 || NE
[E=110][D=U$] || 110 || U$
[E=110][D=FX] || 110 || FX
查看函数 SUBSTRING 和 CHARINDEX。 将它们一起使用,您应该能够提取它。
SUBSTRING(表达式,开始,长度)
CHARINDEX ( expressionToFind ,expressionToSearch [ , start_location ] )
例如:
SELECT SUBSTRING(COL,CHARINDEX('E=',COL)+2,CHARINDEX(']',COL) - CHARINDEX('E=',COL) - 2)
FROM @TABLE
将为您提供 EXCEPTION_CODE 列。
XML 比 charindex
更灵活。 replace
对于准备格式正确的 xml 非常有用。见代码。
;with dat(col, x) as (
select col, cast('<col'+replace(
replace(
replace(col,'=','="'),
']','" '),
'[',' ')+' />' as xml)
from @TABLE
)
select col, t.v.value('@E','int') Exception_code, t.v.value('@D','varchar(100)') [DATA]
from dat cross apply x.nodes('col') t(v)
并且结果如 OP 中所期望的那样。