如何从Server中字符串的开头删除非字母字符。
例:6Hai应该返回Hai,H6ai应该返回H6ai
我正在使用Server 2017。
发布于 2021-03-04 06:14:37
模式可用于替换字符串中的非字母字符,如下所示:
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或者一个函数可以定义为:
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并以下列方式调用该功能:
Select dbo.RemoveNonAlphaCharactersFromStart('6Hai')请参考此答案以删除所有非alpha字符:https://stackoverflow.com/a/1008566/7804477
我已经更新了函数,以便从一开始只删除非字母字符:
Stuff和PatIndex是内置函数.
这是仅在字符串开头进行检查的关键条件:While PatIndex(@KeepValues, @Temp) = 1
Stuff(@Temp, 1, 1, '') --这将用空字符''替换字符串中的第一个字符。(第二个参数是起始位置,第三个参数表示要替换的字符数)
https://stackoverflow.com/questions/66469566
复制相似问题