【叶子函数分享八】取出字符串中的汉字、字母或是数字

本文介绍了一组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')--正常

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值