首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用PATINDEX删除字符

使用PATINDEX删除字符
EN

Stack Overflow用户
提问于 2013-01-18 15:08:05
回答 1查看 2.3K关注 0票数 1

我正在使用我在网上找到的一个函数来尝试从一个字段中删除非法字符。

代码语言:javascript
复制
 Create Function [epacube].[StripSpecs](@myString varchar(500),
  @invalidChars varchar(100)) RETURNS varchar(500) AS Begin

   While PatIndex(@invalidChars, @myString) > 0
      Set @myString = Stuff(@myString, PatIndex(@invalidChars, @myString), 1, '')
   Return @myString End

在我的表中,我将字段值设置为: DATA_NAME = 'Pro$d)uc^t‘。

如果我运行这个查询:

代码语言:javascript
复制
SELECT epacube.StripSpecs (
   DATA_NAME
  ,'%$%') FROM TABLE_DATA

它起作用了,我得到了Prod)uc^t的一个返回值。

但是,如果我添加另一个特殊字符,它将不再起作用:

代码语言:javascript
复制
SELECT epacube.StripSpecs (
   DATA_NAME
  ,'%$)%') FROM TABLE_DATA

返回我的原始值Pro$d)uc^t

有人对我需要做的事情有什么建议吗?

下面的答案是编辑,下面是工作的代码:

代码语言:javascript
复制
Create Function [epacube].[StripSpecs](@myString varchar(500), @invalidChars varchar(100))
RETURNS varchar(500) AS
Begin

  While PatIndex('%[' + @invalidChars + ']%', @myString) > 0
    Set @myString = Stuff(@myString, PatIndex('%[' + @invalidChars + ']%', @myString), 1, '')
  Return @myString
End
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-01-18 15:11:43

LIKE一样,如果您希望指定一组字符中的一个应该匹配,请使用[]将该集合括起来。

代码语言:javascript
复制
SELECT epacube.StripSpecs (
   DATA_NAME
  ,'%[$)]%') FROM TABLE_DATA

尽管就个人而言,考虑到函数和参数的描述,我会在%[]%中添加StripSpecs,并让调用者只给出一个字符列表(如果您不想支持指定的任何其他类型的模式)

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

https://stackoverflow.com/questions/14401740

复制
相关文章

相似问题

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