首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >只从字符串开头替换非alpha字符。

只从字符串开头替换非alpha字符。
EN

Stack Overflow用户
提问于 2021-03-04 06:14:37
回答 1查看 46关注 0票数 0

如何从Server中字符串的开头删除非字母字符。

例:6Hai应该返回HaiH6ai应该返回H6ai

我正在使用Server 2017。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-03-04 06:14:37

模式可用于替换字符串中的非字母字符,如下所示:

代码语言:javascript
复制
Declare @Temp as varchar(50)
set @Temp = '6Hai'
Declare @KeepValues as varchar(50)
    Set @KeepValues = '%[^a-z]%'
    While PatIndex(@KeepValues, @Temp) = 1
        Set @Temp = Stuff(@Temp, 1, 1, '')

select @Temp

或者一个函数可以定义为:

代码语言:javascript
复制
Create Function [dbo].[RemoveNonAlphaCharactersFromStart](@Temp VarChar(1000))
Returns VarChar(1000)
AS
Begin

    Declare @KeepValues as varchar(50)
    Set @KeepValues = '%[^a-z]%'
    While PatIndex(@KeepValues, @Temp) = 1
        Set @Temp = Stuff(@Temp, 1, 1, '')

    Return @Temp
End

并以下列方式调用该功能:

代码语言:javascript
复制
Select dbo.RemoveNonAlphaCharactersFromStart('6Hai')

请参考此答案以删除所有非alpha字符:https://stackoverflow.com/a/1008566/7804477

我已经更新了函数,以便从一开始只删除非字母字符:

StuffPatIndex是内置函数.

这是仅在字符串开头进行检查的关键条件:While PatIndex(@KeepValues, @Temp) = 1

Stuff(@Temp, 1, 1, '') --这将用空字符''替换字符串中的第一个字符。(第二个参数是起始位置,第三个参数表示要替换的字符数)

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

https://stackoverflow.com/questions/66469566

复制
相关文章

相似问题

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