打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
取出字符串中的汉字、字母或是数字

取出字符串中的汉字、字母或是数字

分类: SQL函数分享系列

go

--创建函数(得到字符串中的汉字)

create function [dbo].[m_getchinese]

(

    @chinese nvarchar(max)

)

returns varchar(100)

as

begin

    while patindex('%[^-]%',@chinese) > 0

    begin

       set @chinese = stuff(@chinese,patindex('%[^-]%',@chinese),1,N'');

    end

    return @chinese

end

go

--创建函数(得到字符串中的字母)

create function [dbo].[m_getstr](@maco varchar(100))

returns varchar(max)

as

begin

    while patindex('%[^a-z]%',@maco) > 0

       begin

           set @maco=stuff(@maco,patindex('%[^a-z]%',@maco),1,'')

       end

    return @maco

end

go

--创建函数(得到字符串中的数字)

create function [dbo].[m_getnumber]

(

   @mysql_one nvarchar(200)

)

returns varchar(200)

begin

    declare @mysql_two varchar(200)

    select @mysql_two=

    substring(@mysql_one,patindex('%[0-9.]%',@mysql_one),patindex('%[^0-9.]%',substring(@mysql_one,patindex('%[0-9.]%',@mysql_one),

    len(@mysql_one)-patindex('%[0-9.]%',@mysql_one)+1))-1)

    return @mysql_two;

end

 

--测试

select dbo.[m_getchinese]('China2009中国HRB4-1v')

select dbo.[m_getstr]('China2009中国HRB4-1v')

select dbo.[m_getnumber]('China2009中国HRB4-1v')

 

--运行结果

/*

-----------

中国

-----------

ChinaHRBv

-----------

2009

*/

 

--说明一下

--上面这个取数字是可以取浮点型的

select dbo.[m_getnumber] ('字段.456A(AA)A')--正常

select dbo.[m_getnumber] ('CHinese2.1day')--正常

select dbo.[m_getnumber] ('Name5.01From')--正常

select dbo.[m_getnumber] ('9898Address')--正常

select dbo.[m_getnumber] ('aaaaaForm2.3333')--错误

 

--修正函数

go

/* 取出字符串中间的数字(第二版)*/

create function [dbo].[m_getnumberV2.0]

(

       @mysql_one nvarchar(200)

)

returns varchar(200)

begin

    declare @mysql_two varchar(200)

    declare @sql_one int

    declare @sql_two int

    select @sql_one= patindex('%[0-9.]%',@mysql_one)

    select @sql_two=

    patindex('%[^0-9.]%',

    substring(@mysql_one,patindex('%[0-9.]%',@mysql_one),len(@mysql_one)-patindex('%[0-9.]%',@mysql_one)+1))

    if @sql_two=0

       begin

           select @mysql_two= substring (@mysql_one,@sql_one,len(@mysql_one)+1-@sql_one)

       end

    else

       begin

           select @mysql_two=substring (@mysql_one,@sql_one,@sql_two-1)

       end

    return @mysql_two;

end

 

--测试示例

select dbo.[m_getnumberV2.0] ('字段.456A(AA)A')--正常

select dbo.[m_getnumberV2.0] ('CHinese2.1day')--正常

select dbo.[m_getnumberV2.0] ('Name5.01From')--正常

select dbo.[m_getnumberV2.0] ('9898Address')--正常

select dbo.[m_getnumberV2.0] ('aaaaaForm2.3333')--正常

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
MySQL数据库介绍
[SQL Server] 提取数字、提取英文、提取中文
判断字符串中只包含或不包含某种字符的方法
SQL Server CHARINDEX和PATINDEX详解
SQlserver 创建函数实现只取某个字段的数字部分
SQL Server数据库内容替换方法
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服