首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PATINDEX、通配符和变量

PATINDEX、通配符和变量
EN

Stack Overflow用户
提问于 2017-05-05 15:22:39
回答 3查看 2.2K关注 0票数 0

如何让PATINDEX对包含%字符的变量进行通配符匹配?

在下面,我希望PATINDEX返回‘%3d’的起始位置:

代码语言:javascript
复制
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中删除了%

OEi49j3DNxE%3d

如何查找指定的%3d,而不是3d

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-05-05 15:32:21

您必须用[]包装来转义%符号。为了做到这一点,您必须使变量@cIn更大,以容纳额外的2个字符,只需在执行patindex之前执行替换操作,或者可以在不更改变量大小的情况下内联完成。

代码语言:javascript
复制
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)

代码语言:javascript
复制
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)

您可以在这里阅读更多信息:How do I escape a percentage sign in T-SQL?

票数 1
EN

Stack Overflow用户

发布于 2017-05-05 15:29:00

您可以使用方括号:

代码语言:javascript
复制
SET @cIn = '[%]3d'
代码语言:javascript
复制
select 
   without_brackets = patindex('%'+'%3d'+'%','OEi49j3DNxE%3d')
 , with_brackets    = patindex('%'+'[%]3d'+'%','OEi49j3DNxE%3d')

rextester演示:http://rextester.com/BVA62284

返回:

代码语言:javascript
复制
+------------------+---------------+
| without_brackets | with_brackets |
+------------------+---------------+
|                7 |            12 |
+------------------+---------------+
票数 2
EN

Stack Overflow用户

发布于 2017-05-05 15:45:47

代码语言:javascript
复制
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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43808608

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档