Oracle 获得汉字拼音字母

create or replace function PY(P1 varchar2, P2 INT default 0 ) return varchar2 is
  Result varchar2(32767);
  /*
  获得汉字拼音字母
  入口参数,汉字字符串,是否只取第一个汉字的拼音首字母
  */
  CHAR1 varchar2(2);
  CHAR2 varchar2(2);
  LEN integer;
  N1  integer;
  N2 integer;
  CSOUND varchar2(32767);
begin
            IF P2 = 1 THEN
           LEN := 1;
       ELSE
           LEN := LENGTH(P1);
       END IF;
      
       FOR I IN 1..LEN LOOP
           CHAR2 := SUBSTR(P1, i, 1);
           N1 := FLOOR(ASCII(CHAR2) / 256);
           N2 := MOD(ASCII(CHAR2), 256);
          
           IF N1 = 0 AND N2 <= 129 THEN
               CHAR1 := CHAR2;
           ELSIF N2 <> 127 AND N2 <> 255 AND NOT (N2 >= 0 AND N2 <= 63)
           THEN
              --实现部分
                IF CHAR2 >= '丂' AND CHAR2 < '芭'    THEN CHAR1:= 'A';
                ELSIF CHAR2 >= '芭' AND CHAR2 < '擦' THEN CHAR1 := 'B';
                ELSIF  CHAR2 >= '擦' AND CHAR2 < '搭'THEN CHAR1 :='C';
                ELSIF CHAR2 >= '搭' AND CHAR2 < '蛾' THEN CHAR1 :='D';
                ELSIF CHAR2 >= '蛾' AND CHAR2 < '发' THEN CHAR1 :='E';
                ELSIF CHAR2 >= '发' AND CHAR2 < '噶' THEN CHAR1 :='F';
                ELSIF CHAR2 >= '噶' AND CHAR2 < '哈' THEN CHAR1 :='G';
                ELSIF CHAR2 >= '哈' AND CHAR2 < '击' THEN CHAR1 :='H';
                ELSIF CHAR2 >= '击' AND CHAR2 < '喀' THEN CHAR1 :='J';
                ELSIF CHAR2 >= '喀' AND CHAR2 < '垃' THEN CHAR1 :='K';
                ELSIF CHAR2 >= '垃' AND CHAR2 < '妈' THEN CHAR1 :='L';
                ELSIF CHAR2 >= '妈' AND CHAR2 < '拿' THEN CHAR1 :='M';
                ELSIF CHAR2 >= '拿' AND CHAR2 < '哦' THEN CHAR1 :='N';
                ELSIF CHAR2 >= '哦' AND CHAR2 < '啪' THEN CHAR1 :='O';
                ELSIF CHAR2 >= '啪' AND CHAR2 < '期' THEN CHAR1 :='P';
                ELSIF CHAR2 >= '期' AND CHAR2 < '然' THEN CHAR1 :='Q';
                ELSIF CHAR2 >= '然' AND CHAR2 < '撒' THEN CHAR1 :='R';
                ELSIF CHAR2 >= '撒' AND CHAR2 < '塌' THEN CHAR1 :='S';
                ELSIF CHAR2 >= '塌' AND CHAR2 < '挖' THEN CHAR1 :='T';
                ELSIF CHAR2 >= '挖' AND CHAR2 < '稀' THEN CHAR1 :='W';
                ELSIF CHAR2 >= '稀' AND CHAR2 < '压' THEN CHAR1 :='X';
                ELSIF CHAR2 >= '压' AND CHAR2 < '匝' THEN CHAR1 :='Y';
                ELSIF CHAR2 >= '匝' AND CHAR2 <= '鼱' THEN CHAR1 := 'Z';
                ELSE  CHAR1:='';
                END  IF;                    
          
           ELSE          
               CHAR1 := 'ER';          
           END IF;
          
           CSOUND := CSOUND || CHAR1;
       END LOOP;
      
       RETURN CSOUND;
 
  return Result;
end PY;

--测试用例,在Oracle8i下测试通过。
SELECT PY('中国人民是伟大的') FROM DUAL;
--将会输出 'ZGRMSWDD' 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值