gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 22:55:22 26 4
gpt4 key购买 nike

我有一个包含名称值对的 varchar(max) 字段,在每一行中我都有名称下划线值。

我需要对其进行查询,以便它返回两列中的名称、值对(因此通过解析文本、删除下划线和“新行”字符。

从这里开始

select NameValue from Table

我从哪里得到这段文字:

Name1_Value1
Name2_Value2
Name3_Value3

我想要这个输出

Names  Values
===== ======
Name1 Value1
Name2 Value2
Name3 Value3

最佳答案

SELECT substring(NameValue, 1, charindex('_', NameValue)-1) AS Names, 
substring(NameValue, charindex('_', NameValue)+1, LEN(NameValue)) AS Values
FROM Table

编辑:像这样放入函数或存储过程中并与临时表结合使用的东西应该适用于多行,根据行分隔符,您还应该在开始之前删除 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), @helper)-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

关于sql-server - 如何解析字符串并从中创建多个列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5829543/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com