应用场景:将数据表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

--获取到字段内容并进行处理
    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中使用游标转换数据表中指定字段内容格式(拼音转数字)的更多相关文章

  1. MySQL为数据表的指定字段插入数据

    username not null 没有默认值/有默认值   insert不插入username字段 均不报错 2014年07月23日21:05    百科369 MySQL为数据表的指定字段插入数据 ...

  2. Sqlserver更新数据表xml类型字段内容某个节点值的脚本

    GO USE [JC2010_MAIN_DB] 1.新建备份表JobObjectVersion_JCSchemVersion_BCK) GO IF EXISTS (SELECT * FROM sys. ...

  3. Navicat查询哪些表有指定字段名

    通常需要查询某个字段来自于哪张表,在navicat中没有直接查哪些表有指定字段名的功能,只能用sql来查. 1.(按字段名查表)查询哪些表有指定字段名(比如查字段名article_id)的SQL: S ...

  4. Oracle使用游标删除所有用户数据表中的所有记录脚本

    应用场景:因为数据库中的数据涉及机密信息,希望一次性能删除掉所有数据,只保留数据表结构,供新项目开发程序用 测试结果:经查询已删除所有数据 存在问题:数据表如果存在外键的话下面脚本可能执行不成功,请自 ...

  5. Oracle中使用游标获取指定数据表的所有字段名对应的字符串

    操作步骤:打开PLSQL Developer后,直接执行下面的语句就可以出来 --Oracle中使用游标获取指定数据表的所有字段名对应的字符串 declare mytablename VARCHAR( ...

  6. Oracle 函数 “把当前的用户(审核人,审核通过后)插入到数据表中”

    create or replace function mcode_apply_update_personnel(p_mca_no VARCHAR2, -- 参数(实参) p_action VARCHA ...

  7. Oracle使用游标查询指定数据表的所有字段名称组合而成的字符串

    应用场合:参考网上查询数据表的所有字段名代码,使用游标生成指定单个表的所有字段名跟逗号组成的用于select  逗号隔开的字段名列表 from字符串等场合. 查询结果输出如下: 当前数据表TB_UD_ ...

  8. 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据

    使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...

  9. SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int

    --SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int --关键说明:--1.从系统表syscolumns中的查询所有xtype='48'的记录得到类型为[tinyint]的字段- ...

随机推荐

  1. [UOJ UNR#2 UOJ拯救计划]

    来自FallDream的博客,未经允许,请勿转载,谢谢. 传送门 感觉这题有点神... 模数是6比较奇怪,考虑计算答案的式子. Ans=$\sum_{i=1}^{k} P(k,i)*ans(i)$ a ...

  2. Java并发编程:JMM(Java内存模型)和volatile

    1. 并发编程的3个概念 并发编程时,要想并发程序正确地执行,必须要保证原子性.可见性和有序性.只要有一个没有被保证,就有可能会导致程序运行不正确. 1.1. 原子性 原子性:即一个或多个操作要么全部 ...

  3. Spring 自带的定时任务Scheduled

    1.注解@Scheduled 可以作为一个触发源添加到一个方法中,例如,以下的方法将以一个固定延迟时间5秒钟调用一次执行,这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执 ...

  4. Java8-理解Colloctor

    上一节学习了Java8中比较常用的内置collector的用法.接下来就来理解下collector的组成. Collector定义 Collector接口包含了一系列方法,为实现具体的归约操作(即收集 ...

  5. Maven之自定义archetype生成项目骨架

    Maven之自定义archetype生成项目骨架(一) http://blog.csdn.net/sxdtzhaoxinguo/article/details/46895013

  6. Just for mysql

    mysql的下载与安装 由于学校开设了数据库专业,并且最近准备在做一个web端的设计,虽然本人是负责前端(当然,前端技术也很LOW),但因种种原因,准备开始学习数据库相关的知识,以mysql为例. 昨 ...

  7. js error

    0x800a0259 - JavaScript 运行时错误: 未知的运行时错误 <p id="navigatorInfo"></p> var txt = & ...

  8. 4月18开始看《C++Primer Plus》

    好久没有写博客了,之前也说过水平有限,也写不出什么技术博客,只能写些感悟. 过年之后,陆续做了2.3个项目,刚开始可能不太熟悉流程,怎么和页面传数据?最近一个项目1/2天就写完代码了,真的很简单,主要 ...

  9. jenkins部署.net平台自动化构建

    在引入自动化部署工具的时候,我们对比了jenkins和gitlab CI,jenkins有非常丰富的插件,配置起来方便.gitlab CI更倾向于脚本配置,当然jenkins也可以使用pipeline ...

  10. 用go实现常用算法与数据结构——队列(queue)

    queue 简介 队列是一种非常常见的数据结构,日常生活中也能经常看到.一个典型的队列如下图(图片来自 segmentfault): 可以看出队列和我们日常生活中排队是基本一致的.都遵循 FIFO(F ...