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


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

由于该字段在项目最初设计中没有严格控制数据质量,导致用户在输入时包含了很多非电话的信息,如用户名字等(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

测试结果:

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM