如何解析字符串并从中创建多个列?

LaB*_*cca 5 sql-server text-parsing sql-server-2008

我有一个varchar(max)包含名称值对的字段,在每行中我都有名称UnderScore Value.

我需要对它进行查询,以便它返回两列中的Name,Value对(因此通过解析文本,删除下划线和"new line"char.

所以从此

select NameValue from Table
Run Code Online (Sandbox Code Playgroud)

我在哪里得到这个文字:

Name1_Value1
Name2_Value2
Name3_Value3
Run Code Online (Sandbox Code Playgroud)

我想有这个输出

Names  Values
=====  ======
Name1  Value1
Name2  Value2
Name3  Value3
Run Code Online (Sandbox Code Playgroud)

Oca*_*tal 8

SELECT substring(NameValue, 1, charindex('_', NameValue)-1) AS Names, 
  substring(NameValue, charindex('_', NameValue)+1, LEN(NameValue)) AS Values
FROM Table
Run Code Online (Sandbox Code Playgroud)

编辑:这样的东西放在一个函数或存储过程与临时表结合应该适用于多行,具体取决于您应该CHAR(13)在开始之前删除的行分隔符:

DECLARE @helper varchar(512)
DECLARE @current varchar(512)
SET @helper = NAMEVALUE
WHILE CHARINDEX(CHAR(10), @helper) > 0 BEGIN
    SET @current = SUBSTRING(@helper, 1, CHARINDEX(CHAR(10), NAMEVALUE)-1)
    SELECT SUBSTRING(@current, 1, CHARINDEX('_', @current)-1) AS Names, 
      SUBSTRING(@current, CHARINDEX('_', @current)+1, LEN(@current)) AS Names
    SET @helper = SUBSTRING(@helper, CHARINDEX(CHAR(10), @helper)+1, LEN(@helper))
END
SELECT SUBSTRING(@helper, 1, CHARINDEX('_', @helper)-1) AS Names, 
  SUBSTRING(@helper, CHARINDEX('_', @helper)+1, LEN(@helper)) AS Names
Run Code Online (Sandbox Code Playgroud)