sql查询在字符之间获取单词

时间:2011-05-02 09:20:44

标签: sql-server-2005

我有问题,我有一个字符串,我需要得到它的一个特定部分。

例如:

    \Stack\Over\Programming\Users\

我需要从上面的字符串中“编程”。

3 个答案:

答案 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中没有内置的。

How do I split a string so I can access item x?