我有问题,我有一个字符串,我需要得到它的一个特定部分。
例如:
\Stack\Over\Programming\Users\
我需要从上面的字符串中“编程”。
答案 0 :(得分:1)
DECLARE @TExt NVARCHAR(MAX)= '\Stack\Over\Programming\Users\'
DECLARE @Delimiter VARCHAR(1000)= '\' ;
WITH numbers
AS ( SELECT ROW_NUMBER() OVER ( ORDER BY o.object_id, o2.object_id ) Number
FROM sys.objects o
CROSS JOIN sys.objects o2
),
c AS ( SELECT Number CHARBegin ,
ROW_NUMBER() OVER ( ORDER BY number ) RN
FROM numbers
WHERE SUBSTRING(@text, Number, LEN(@Delimiter)) = @Delimiter
),
res
AS ( SELECT CHARBegin ,
CAST(LEFT(@text, charbegin) AS NVARCHAR(MAX)) Res ,
RN
FROM c
WHERE rn = 1
UNION ALL
SELECT c.CHARBegin ,
CAST(SUBSTRING(@text, res.CHARBegin+1,
c.CHARBegin - res.CHARBegin-1) AS NVARCHAR(MAX)) ,
c.RN
FROM c
JOIN res ON c.RN = res.RN + 1
)
SELECT *
FROM res
<强>结果:强>
CHARBegin |Res |RN
1 | \ |1
7 |Stack |2
12 |Over |3
24 |Programming |4
30 |Users |5
在你的情况下,你需要最后一个声明
SELECT * FROM res WHERE Rn=4
答案 1 :(得分:1)
如果它始终是第3和第4 \
之间的单词,那么下面就可以了。
DECLARE @String VARCHAR(32)
SET @String = '\Stack\Over\Programming\Users\'
SELECT SUBSTRING(
@String
, CHARINDEX('\', @String, CHARINDEX('\', @String, CHARINDEX('\', @String, 1) + 1) + 1) + 1
, CHARINDEX('\', @String, CHARINDEX('\', @String, CHARINDEX('\', @String, CHARINDEX('\', @String, 1) + 1) + 1) + 1)
- CHARINDEX('\', @String, CHARINDEX('\', @String, CHARINDEX('\', @String, 1) + 1) + 1) - 1)
答案 2 :(得分:0)
您需要在SQL中创建字符串拆分功能。遗憾的是,MS SQL中没有内置的。