全角转半角函数

Posted 瀚高PG实验室

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了全角转半角函数相关的知识,希望对你有一定的参考价值。

瀚高数据库
目录
环境
文档用途
详细信息

环境
系统平台:银河麒麟U系(CPU飞腾)4
版本:4.5
文档用途
将全角字符数字等转换为半角。

详细信息

---全角转半角函数如下

CREATE OR REPLACE FUNCTION convertstring(text)

 RETURNS text AS

$$

 DECLARE len INTEGER;

 DECLARE retval text;

 DECLARE tmp text;

 DECLARE asciival INT4;



 BEGIN

   --字符串字符个数

   SELECT textlen($1) INTO len;



   SELECT '' INTO retval;



   --循环

   FOR i IN 1..len LOOP

     --取单个字符

     SELECT substring($1, i, 1) INTO tmp;

     SELECT ascii(tmp) INTO asciival;



       BEGIN

         --全角转半角

         IF (asciival = 12288) THEN  --空格

           asciival = 32;

         END IF;

         IF (asciival > 65280) AND (asciival < 65375) THEN

           SELECT asciival-65248 INTO asciival;

         END IF;

       END;



     SELECT chr(asciival) INTO tmp;



     SELECT textcat(retval, tmp) INTO retval;

   END LOOP;



   RETURN retval;

 END;

 $$

   LANGUAGE 'plpgsql'




以上是关于全角转半角函数的主要内容,如果未能解决你的问题,请参考以下文章

java全角转半角

java 全角半角转换函数

全角半角转换

JavaScript 实时 全角转半角

输入法全角自动转半角的技术处理

转: js实现全角半角检测的方法