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
测试结果: