今天公司项目中遇到了一个需求,要求提取用户电话号码字段中的所有电话信息。

由于该字段在项目最初设计中没有严格控制数据质量,导致用户在输入时包含了很多非电话的信息,如用户名字等(136 **** **** 张san)

要求提取出当中的136********

思路:创建函数,依次判断每个字符的ASCII码是否在[0,9]中,提取该部分内容。

Create Function USF_ExtractNumeric
(
    @inputStr nvarchar(50)
)
Returns nvarchar(50)
AS
Begin
    Declare @outputStr nvarchar(50)
    Set @outputStr = ''
    If ISNUMERIC(@inputStr) = 1
    Begin
        Return @inputStr
    End
    
    Declare @I Int
    Set @I = 1
    While @I <= Len(@inputStr)
    Begin
        If ASCII(SUBSTRING(@inputStr,@I,1)) <= 57 and ASCII(SUBSTRING(@inputStr,@I,1)) >= 48
        Begin
            Set @outputStr = @outputStr + SUBSTRING(@inputStr,@I,1)
        End
        Set @I = @I + 1
    End
    Return @outputStr
End

测试结果:

SQL Server提取字段中的所有数字

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-01-09
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-07-18
  • 2021-06-10
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-12-10
  • 2022-12-23
  • 2022-12-23
  • 2021-10-21
  • 2021-12-22
相关资源
相似解决方案