首页 > 数据库技术 > 详细

SqlServer数据库全角转换成半角

时间:2016-02-07 14:59:58      阅读:284      评论:0      收藏:0      [点我收藏+]
复制代码 代码如下:

CREATE   FUNCTION   f_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
SELECT   @pat=N‘%[!-~]%‘,@step=-65248,
@str=REPLACE(@str,N‘  ‘,N‘   ‘)
ELSE
SELECT   @pat=N‘%[!-~]%‘,@step=65248,
@str=REPLACE(@str,N‘   ‘,N‘  ‘)
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调用:update table1 set column1=dbo.f_Convert(column1,0);
 

SqlServer数据库全角转换成半角

原文:http://www.jb51.net/article/34681.htm

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!