本文介紹了如何在SQL Server中替換2個特定字符之間的任何字符的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在嘗試替換包含這兩個字符倍數的字符串中介于兩個特定字符之間的任何字符。將其視為CSV格式。
下面是我在該字段中獲得的數據的示例:
0001, ABCD1234;0002, EFGH432562;0003, IJKL1345hsth;...
我需要從其中檢索的是‘,’之前的所有部分,而不是‘,’和‘;’之間的部分
我嘗試了這些公式,但沒有成功
SELECT REPLACE(fieldname, ',[A-Z];', ' ') FROM ...
or
SELECT REPLACE(fieldname, ',*;', ' ') FROM ...
我需要獲取
0001 0002 0003
有沒有辦法做到這一點?
推薦答案
您可以CROSS APPLY
STRING_SPLIT
使用STRING_AGG(自SQL Server2017起)將數字粘合在一起。
select id, codes from your_table cross apply ( select string_agg(left(value, patindex('%_,%', value)), ' ') as codes from string_split(fieldname, ';') s where value like '%_,%' ) ca; GO
id | 代碼 |
---|---|
1 | 0001 0002 0003 |
db;&>小提琴here
演示
額外
以下是也可以在SQL Server 2014中使用的版本。
靈感來自@AaronBertrand的研究
UDF使用遞歸CTE拆分字符串。
而FOR XML
技巧是用來把數字粘在一起的。
CREATE FUNCTION dbo.fnString_Split ( @str nvarchar(4000), @delim nchar(1) ) RETURNS TABLE WITH SCHEMABINDING AS RETURN ( WITH RCTE AS ( SELECT 1 AS ordinal , ISNULL(NULLIF(CHARINDEX(@delim, @str),0), LEN(@str)) AS pos , LEFT(@str, ISNULL(NULLIF(CHARINDEX(@delim, @str),0)-1, LEN(@str))) AS value UNION ALL SELECT ordinal+1 , ISNULL(NULLIF(CHARINDEX(@delim, @str, pos+1), 0), LEN(@str)) , SUBSTRING(@str, pos+1, ISNULL(NULLIF(CHARINDEX(@delim, @str, pos+1),0)-pos-1, LEN(@str)-pos )) FROM RCTE WHERE pos < LEN(@str) ) SELECT ordinal, value FROM RCTE );
SELECT id, codes FROM your_table CROSS APPLY ( SELECT RTRIM(( SELECT LEFT(value, PATINDEX('%_,%', value))+' ' FROM dbo.fnString_Split(fieldname, ';') AS spl WHERE value LIKE '%_,%' ORDER BY ordinal FOR XML PATH(''), TYPE).value(N'./text()[1]', N'nvarchar(max)') ) AS codes ) ca OPTION (MAXRECURSION 250);
id | 代碼 |
---|---|
1 | 0001 0002 0003 |
db;&>小提琴here
演示
UDF的替代版本(無遞歸)
CREATE FUNCTION dbo.fnString_Split
(
@str NVARCHAR(4000),
@delim NCHAR(1)
)
RETURNS @tbl TABLE (ordinal INT, value NVARCHAR(4000))
WITH SCHEMABINDING
AS
BEGIN
DECLARE @value NVARCHAR(4000)
, @pos INT = 0
, @ordinal INT = 0;
WHILE (LEN(@str) > 0)
BEGIN
SET @ordinal += 1;
SET @pos = ISNULL(NULLIF(CHARINDEX(@delim, @str),0), LEN(@str)+1);
SET @value = LEFT(@str, @pos-1);
SET @str = SUBSTRING(@str, @pos+1, LEN(@str));
INSERT INTO @tbl (ordinal, value)
VALUES (@ordinal, @value);
END;
RETURN;
END;
這篇關于如何在SQL Server中替換2個特定字符之間的任何字符的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,