SQL-запрос, чтобы получить слово между символами - PullRequest
1 голос
/ 02 мая 2011

У меня проблема с тем, что у меня есть строка, и мне нужно получить определенную ее часть.

Например:

    \Stack\Over\Programming\Users\

Мне нужно "Программирование" из приведенной выше строки.

Ответы [ 3 ]

1 голос
/ 02 мая 2011
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 голос
/ 02 мая 2011

Если это всегда слово между 3-м и 4-м \, то сработает следующее.

0 голосов
/ 02 мая 2011

вам нужно будет создать функцию разделения строк в SQL.к сожалению, в MS SQL нет ни одного встроенного.

Как разделить строку, чтобы получить доступ к элементу x?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...