• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

用自定义函数替换SQL中的全角数字为半角数字

发布: 2007-7-02 11:08 | 作者: admin | 来源: | 查看: 33次 | 进入软件测试论坛讨论

领测软件测试网
在我们使用MSSQL的时候,有时表中有一些是全角的数字,但我们的系统不能够正确的使用它们,这时我们要把他们替换为半角数字。而SQL自己好像没有这个函数。

没有,我们自己动手:

下面就是我自己写的一个函数,当然,我的数据量小,没有考虑性能

--  把全角数据转换成半角数字(注意,这个只能转换全是全角的,在第一个半角数据时返回)--  公司:石家庄创联科技--  编写:牛昆亮  QQ:273352165

create function  ufn_convertWideNumericToAnsi( @vstrIn varchar(1000))returns varchar(4000)asbegin declare @strReturn varchar(4000)  ,@bin  varbinary(4000)  ,@str  varchar(4000)  ,@stmp varchar(4)  ,@i   int  ,@len  int--  ,@vstrIn varchar(1000)

--set @vstrIn =@#031851001845@# set @strReturn=@#@# set @bin=convert(varbinary(4000),@vstrIn) exec master..xp_varbintohexstr @bin, @str out  select @str=stuff(@str,1,2,@#@#)  set @len=len(@str) set @i=1 while @i<@len begin set @stmp = substring(@str,@i,4) if(substring(@stmp,1,1) <> @#A@#)  return @vstrIn set @stmp = replace(@stmp,@#A@#,@#@#) set @stmp = replace(@stmp,@#B@#,@#@#)--print @stmp set @stmp = cast((convert(int,@stmp)-30) as varchar(1)) set @strReturn = @strReturn + @stmp  set @i=@i+4 end--print @strReturnreturn  @strReturnend

示例

select @#031851001845@# as ORG,  dbo.ufn_convertWideNumericToAnsi(@#031851001845@#) DES

ORG                      DES           ------------------------ ---------------------------031851001845             031851001845

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网