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