PATINDEX, подстановочные знаки и переменные

Как вы получаете PATINDEX чтобы сделать сопоставление с подстановочным знаком для переменной, которая включает в себя % персонаж?

В следующем я хочу PATINDEX вернуть начальную позицию "% 3d":

DECLARE @inputText as VARCHAR(100)
DECLARE @s as Int   
DECLARE @cIn as CHAR(3)

SET @inputText = 'OEi49j3DNxE%3d'
SET @cIn = '%3d'
SET @s = PATINDEX('%' + @cIn +'%', @InputText)

Как вы можете видеть из @InputTextначинается с позиции 12.

OEi49j3DNxE % 3d

тем не мение PATINDEX кажется, возвращает начальную позицию на 7, потому что, кажется, сбросить % от CIn:

OEi49j3D NxE% 3d

Как мне найти %3d как указано, а не 3d?

3 ответа

Решение

Вы должны экранировать знак%, заключив его в []. Чтобы сделать это, вам нужно будет увеличить переменную @cIn, чтобы вместить дополнительные 2 символа, и просто выполнить замену, прежде чем выполнять patindex, или вы можете сделать это встроенным без изменения размеров переменной.

DECLARE @inputText as VARCHAR(100)
DECLARE @s as Int   
DECLARE @cIn as CHAR(5)

SET @inputText = 'OEi49j3DNxE%3d'
SET @cIn = '%3d'
SET @cIn = REPLACE(@cIn, '%', '[%]')
SET @s = PATINDEX('%' + @cIn +'%', @InputText)

ИЛИ ЖЕ

DECLARE @inputText as VARCHAR(100)
DECLARE @s as Int   
DECLARE @cIn as CHAR(5)

SET @inputText = 'OEi49j3DNxE%3d'
SET @cIn = '%3d'
SET @s = PATINDEX('%' + replace(@cIn, '%', '[%]') +'%', @InputText)

Вы можете прочитать больше о здесь: Как мне избежать знака процента в T-SQL?

Вы можете использовать квадратные скобки:

SET @cIn = '[%]3d'

select 
   without_brackets = patindex('%'+'%3d'+'%','OEi49j3DNxE%3d')
 , with_brackets    = patindex('%'+'[%]3d'+'%','OEi49j3DNxE%3d')

демонстрационный ролик: http://rextester.com/BVA62284

возвращает:

+------------------+---------------+
| without_brackets | with_brackets |
+------------------+---------------+
|                7 |            12 |
+------------------+---------------+
DECLARE @inputText as VARCHAR(100)
DECLARE @s as Int   
DECLARE @cIn as CHAR(3)

SET @inputText = 'OEi49j3DNxE%3d'
SET @cIn = '[%]3d'
SET @s = PATINDEX('%' + @cIn + '%' , @InputText)

select @s

Выход: 12

Другие вопросы по тегам