SQL 全角和半角转换

数据库系统中,经常有些用户在输入数据的时候会不小用使用全角输入,这就有可能会导致我们的程序出错,如何解决此类问题了.

首先我们来看一个测试代码:
    select cast('111' as intas num1
 
select  cast('111' as intas num2

运行结果:
第一个正确显示:  111
第二个则报错:      在将 varchar 值 '111' 转换成数据类型 int 时失败。
  
下面使用自定义标量函数来解决这个问题:


if object_id(N'u_convert',N'FN'is not null
 
drop   function u_convert
GO  
/*
 转换原理 
全角字符unicode编码从65281~65374  
半角字符unicode编码从33~126  
空格比较特殊,全角为 12288,半角为   32  
而且除空格外,全角/半角按unicode编码排序在顺序上是对应的  
所以可以直接通过用+-法来处理非空格数据,对空格单独处理  
like的时候,指定排序规则   COLLATE   Latin1_General_BIN  
是保证字符顺序按unicode编码排序  

*/  
create   function   u_convert(  
@str   nvarchar(4000),   --要转换的字符串  
@flag   bit              --转换标志,0转换成半角,1转换成全角  
)
returns   nvarchar(4000)  
AS  
begin  
    
declare   
          
@pat nvarchar(8),
          
@step   int,
          
@i   int,
          
@spc   int  
    
if  @flag=0 
     
begin 
       
select   @pat=N'%[!-~]%',@step=-65248,  
       
@str=replace(@str,N' ',N'   ')  
     
end
    
else  
     
begin
       
select   @pat=N'%[!-~]%',@step=65248,  
       
@str=replace(@str,N'   ',N' ')  
     
end
    
set   @i=patindex(@pat   collate LATIN1_GENERAL_BIN,@str)  
    
while   @i>0  
       
select   @str=replace(@str,  
    
substring(
               
@str,@i,1), 
               
nchar(unicode(substring(@str,@i,1))+@step)),
               
@i=patindex(@pat   collate   LATIN1_GENERAL_BIN,@str)  
     
return(@str)  
end  
GO  

测试语句:
select dbo.u_convert('11',1) as [a],'11' as [b],dbo.u_convert('111',0) as [c]

本帖来源:http://www.cnblogs.com/huangting2009/archive/2009/07/08/1519189.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值