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

2022-12-18 07:24:14   文档大全网     [ 字体: ] [ 阅读: ]

#文档大全网# 导语】以下是®文档大全网的小编为您整理的《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=

1


少年易学老难成,一寸光阴不可轻 - 范文大全



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)

2


本文来源:https://www.wddqxz.cn/5fde3b87d2f34693daef5ef7ba0d4a7302766c0c.html

相关推荐