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
--获取到字段内容并进行处理
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中使用游标转换数据表中指定字段内容格式(拼音转数字)的更多相关文章
- MySQL为数据表的指定字段插入数据
username not null 没有默认值/有默认值 insert不插入username字段 均不报错 2014年07月23日21:05 百科369 MySQL为数据表的指定字段插入数据 ...
- Sqlserver更新数据表xml类型字段内容某个节点值的脚本
GO USE [JC2010_MAIN_DB] 1.新建备份表JobObjectVersion_JCSchemVersion_BCK) GO IF EXISTS (SELECT * FROM sys. ...
- Navicat查询哪些表有指定字段名
通常需要查询某个字段来自于哪张表,在navicat中没有直接查哪些表有指定字段名的功能,只能用sql来查. 1.(按字段名查表)查询哪些表有指定字段名(比如查字段名article_id)的SQL: S ...
- Oracle使用游标删除所有用户数据表中的所有记录脚本
应用场景:因为数据库中的数据涉及机密信息,希望一次性能删除掉所有数据,只保留数据表结构,供新项目开发程序用 测试结果:经查询已删除所有数据 存在问题:数据表如果存在外键的话下面脚本可能执行不成功,请自 ...
- Oracle中使用游标获取指定数据表的所有字段名对应的字符串
操作步骤:打开PLSQL Developer后,直接执行下面的语句就可以出来 --Oracle中使用游标获取指定数据表的所有字段名对应的字符串 declare mytablename VARCHAR( ...
- Oracle 函数 “把当前的用户(审核人,审核通过后)插入到数据表中”
create or replace function mcode_apply_update_personnel(p_mca_no VARCHAR2, -- 参数(实参) p_action VARCHA ...
- Oracle使用游标查询指定数据表的所有字段名称组合而成的字符串
应用场合:参考网上查询数据表的所有字段名代码,使用游标生成指定单个表的所有字段名跟逗号组成的用于select 逗号隔开的字段名列表 from字符串等场合. 查询结果输出如下: 当前数据表TB_UD_ ...
- 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...
- SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int
--SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int --关键说明:--1.从系统表syscolumns中的查询所有xtype='48'的记录得到类型为[tinyint]的字段- ...
随机推荐
- hdu 5437Alisha’s Party(优先队列)
题意:邀请k个朋友,每个朋友带有礼物价值不一,m次开门,每次开门让一定人数p(如果门外人数少于p,全都进去)进来,当所有人到时会再开一次,每次都是礼物价值高的人先进. /*小伙伴最开始gg了,结果发现 ...
- [BZOJ]3671 随机数生成器(Noi2014)
洛谷上卡不过去的朋友们可以来看看小C的程序(小C才不是标题党呢!) Description Input 第1行包含5个整数,依次为 x_0,a,b,c,d ,描述小H采用的随机数生成算法所需的随机种子 ...
- [BZOJ]4650 优秀的拆分(Noi2016)
比较有意思的一道后缀数组题.(小C最近是和后缀数组淦上了?) 放在NOI的考场上.O(n^3)暴力80分,O(n^2)暴力95分…… 即使想把它作为一道签到题也不要这么随便啊摔(╯‵□′)╯︵┻━┻ ...
- 关于一些基础的Java问题的解答(六)
26. ThreadPool用法与优势 ThreadPool即线程池,它是JDK1.5引入的Concurrent包中用于处理并发编程的工具.使用线程池有如下好处: 降低资源消耗:通过重复利用已创建的线 ...
- 前端开发利器VSCode
最近找到一款非常好用的开发利器,VSCode.一直认为微软做的东西都很一般,这个软件让我刮目相看了. 之前使用webstorm卡的不行,换了这个非常好用. 用着还不错,这里记录下一些使用的心得. VS ...
- 利用Python进行数据分析——Ipython
利用Python进行数据分析--Ipython 一.Ipython一些常用命令 1.TAB自动补全 2.变量+? 显示相关信息 3.函数名+??可以获取函数的代码 4.使用通配符* np.load? ...
- python3中替换python2中cmp函数的新函数分析(lt、le、eq、ne、ge、gt)
本文地址:http://blog.csdn.net/sushengmiyan/article/details/11332589 作者:sushengmiyan 在python2中我们经常会使用cmp函 ...
- ngx.re.match
ngx.re.match syntax: captures, err = ngx.re.match(subject, regex, options?, ctx?, res_table?) contex ...
- sublime snippet 示例
<snippet> <content><![CDATA[local ${1:M} = {} function ${1:M}.new(cls, self) self = s ...
- Weblogic 12c 集群环境搭建
本文是在windows7操作系统下配置的,jdk版本1.7 ,weblogic版本12.1.3.0.0. 搭建集群前的规划 其中AdminServer是总控制端,server1.server2.ser ...