SqlServer数据库全角转换成半角
前端之家收集整理的这篇文章主要介绍了
SqlServer数据库全角转换成半角,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
<div class="codetitle"><a style="CURSOR: pointer" data="85703" class="copybut" id="copybut85703" onclick="doCopy('code85703')"> 代码如下:
<div class="codebody" id="code85703">
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,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,1))+@step))
,@i=PATINDEX(@pat COLLATE LATIN1_GENERAL_BIN,@str)
RETURN(@str)
END
GO
调用:update table1 set column1=dbo.f_Convert(column1,0);