Home  >  Article  >  Database  >  Oracle中使用游标转换数据表中指定字段内容格式(拼音转数字)

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

WBOY
WBOYOriginal
2016-06-07 16:40:491194browse

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 is

var_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

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn