Welcome 微信登录

首页 / 数据库 / MySQL / Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)

应用场景:将Oracle数据表TB_USER中字段NNDP的内容中为[sannanyinv]转换为[3男1女]主要脚本:一个游标脚本+分割字符串函数+拼音转数字脚本操作步骤如下:1、创建类型
create or replace type splitTable is table of varchar2(100);2、创建函数fn_splitString(功能是将字符串分割成多条记录)
--测试语句select * from table(fn_splitString("ernanyinv","nan"))--fn_splitString函数脚本代码
create or replace function fn_splitString(var_str in varchar2, var_split in varchar2)return splitTable isvar_out   splitTable;
var_tmp   varchar2(4000);
var_element varchar2(4000);begin
var_tmp := var_str;
var_out := splitTable();
--如果存在匹配的分割符
while instr(var_tmp, var_split) > 0 loop
    var_element := substr(var_tmp, 1, instr(var_tmp, var_split) - 1);
    var_tmp   := substr(var_tmp,
                          instr(var_tmp, var_split) + length(var_split),
                          length(var_tmp));
    --var_out.extend(1);
    var_out.extend;
    var_out(var_out.count) := var_element;
end loop;--var_out.extend(1);
var_out.extend;
var_out(var_out.count) := var_tmp;return var_out;
end fn_splitString; 3、创建函数fn_getNumber(功能是将数字拼音字符串转为数字)
--测试语句SELECT fn_getNumber("yi") from dual;--fn_getNumber函数脚本代码create or replace function fn_getNumber(p_str in varchar2)
return VARCHAR2
as
 v_compare VARCHAR2(20);
 v_return    VARCHAR2(1);
begin
   IF p_str IS NULL
   THEN
        RETURN "";
   END IF; 
      v_compare:=  Lower(p_str);
       CASE
             WHEN v_compare = "yi"
             THEN
                  v_return := "1";
             WHEN v_compare = "er"
             THEN
                  v_return := "2";
             WHEN v_compare = "san"
             THEN
                  v_return := "3";
             WHEN v_compare = "si"
             THEN
                  v_return := "4";
             WHEN v_compare = "wu"
             THEN
                  v_return := "5";
             WHEN v_compare = "liu"
             THEN
                  v_return := "6";
             WHEN v_compare = "qi"
             THEN
                  v_return := "7";
             WHEN v_compare = "ba"
             THEN
                  v_return := "8";
             WHEN v_compare = "jiu"
             THEN
                  v_return := "9";
             ELSE
                  v_return := "0";
            END CASE;
    return v_return;
end fn_getNumber; 4、运行转换脚本(功能是将数据表中指定字段内容转换为所需要的格式)--Oracle中使用游标转换数据表中指定字段内容格式由拼音到数字
--update TB_USER set NNDP="sannansinv";
--定义游标
declare
femalenumber number:=0;--定义最后的男性数量
malenumber number:=0;--定义最后的女性数量femalestring VARCHAR2(20):="er";--定义男性拼音分割符
malestring VARCHAR2(20):="sinv";--定义女性拼音分割符columnstring NVARCHAR2(40):=""; --定义数据表字段取出的字符串内容 
resultstring  NVARCHAR2(40):="";--定义最后处理的字符串cursor mycursor is select * from TB_USER where NNDP<>" "; --从数据表查询对应要更新的记录:
myrecord mycursor%rowtype;  --定义游标记录类型 
Counter int :=0;
begin 
open mycursor;  --打开游标 
if mycursor%isopen  then  --判断打开成功 
loop --循环获取记录集   
fetch mycursor into myrecord; --获取游标中的记录        if mycursor%found then  --游标的found属性判断是否有记录 
begin --获取到字段内容并进行处理
    columnstring:=myrecord.NNDP;
    --dbms_output.put_line("当前字段对应的所有字符串"||columnstring); --显示结果 
    resultstring:="";
    declare  cursor mycursor1 is select * from table(fn_splitString(columnstring,"nan"));
    myrecord1 mycursor1%rowtype;  --定义游标记录类型 
    Counter1 int :=0; 
    begin 
    open mycursor1;  --打开游标 
   
    if mycursor1%isopen  then  --游标打开成功 
    loop --循环获取记录集   
    fetch mycursor1 into myrecord1; --获取游标中的记录            if mycursor1%found then  --判断是否有记录 
    begin
     
    --判断是否取到男性数量开始
    if length(resultstring)>0 then
     begin
       --获取女性数量字符串
       SELECT REPLACE(myrecord1.column_value,"nv","") into femalestring from dual;
       dbms_output.put_line("女性数字拼音"||femalestring);
       --转换数字拼音为数字字符 
       select fn_getNumber(femalestring) into femalenumber from dual;
       resultstring:=resultstring||femalenumber||"女";
       --dbms_output.put_line("女性字符串"||femalestring); --显示结果     
     end;
    else
     begin
        --获取男性数量字符串
       malestring:=myrecord1.column_value;
       dbms_output.put_line("男性数字拼音"||malestring);
       --转换数字拼音为数字字符
       select fn_getNumber(malestring) into malenumber from dual;
       resultstring:=malenumber||"男";
        --dbms_output.put_line("男性字符串"||resultstring); --显示结果
     end;
    end if;
    --判断是否取到男性数量结束
   
    end;    else
    exit;
    end if;--结束判断是否有记录
     
    end loop; 
    else   
        dbms_output.put_line("游标1没有打开"); 
    end if;      --结束打开游标成功
    close mycursor1;
    end;    dbms_output.put_line(resultstring); --显示结果
   
    --更新数据库数据
    update TB_USER set NNDP=resultstring where ID= myrecord.ID;   
   
    --select NNDP from TB_USER where NNDP <> " ";   end;else           
exit;
end if;
 
end loop; 
else   
dbms_output.put_line("游标0没有打开"); 
end if;   
close mycursor;
end; 附:运行截图更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12本文永久更新链接地址