网站首页 > 技术文章 正文
Oracle在plsql中创建表类型数据
表类型的操作在oracle中会稍微有些复杂,我们这里通过一个简单的例子,来给大家做个讲解。
前提条件:
create table qq_games(
qq number,
game varchar2(50)
);
insert into qq_games values(11111,'a-b-c');
insert into qq_games values(22222,'b-c');
要将这个表格的数据,查询成下面的格式:
11111 a
11111 b
11111 c
22222 b
22222 c
要拆分数据,并且以一个新表的结构来进行展示的话,需要有如下的步骤:
-- 在oracle里面,要自己先创建一个表类型,因为表类型有多个字段,所以不能直接创建的,需要先创建数据库最顶层的对象object
create or replace type 类型名字 is object (字段名字1 数据类型, 字段名字2 数据类型, ...);
create or replace type qq is object(qq number, game varchar2(50));
通过这个object创建一个表格的结构:
create or replace type 类型名字 is table of object类型的名字;
create or replace type qq_t is table of qq;
-- 通过函数,读取原表的数据,并且对数据进行计算,最后展示成一个目标表格的样式
create or replace function fun_qq
-- 定义函数返回的一个表格的类型
return qq_t
as
--初始化这个表格
t qq_t:=qq_t();
--定义一个变量来接收i.game的内容
s varchar2(50);
le number;
--定义表的行号,默认从1开始
c number:=1;
begin
--一行行的读取 qq_games 行数据,这里用的是游标
for i in (select * from qq_games) loop
--每一个i就是一行数据,里面有 i.qq i.game
--现在对i.game进行数据的拆分
s:=i.game;
--判断s里面有多少个分隔符
le:=length(s)-length(replace(s,'-',''));
--有几个分隔符就循环几次
for j in 1..le loop
--获取第一个分隔符前面的内容 例如 a-b-c 那么就是获取 a
--将数据放入表类型,需要将表序号往下挪一格
t.extend;
t(c):=qq(i.qq,substr(s,1,instr(s,'-')-1));
--写入了第一个分隔符之前的数据,将后面的数据重新截取
s:=substr(s,instr(s,'-')+1);
--写完数据让行号—+1
c:=c+1;
end loop;
--再额外的写入最后剩下的字符串
t.extend;
t(c):=qq(i.qq,s);
c:=c+1;
end loop;
-- 返回写入了数据的表类型变量 t
return t;
end;
-- 查看表类型函数执行的结果
select * from table(fun_qq);
猜你喜欢
- 2024-10-18 MyBatis项目实战 快速将MySQL转换成Oracle语句
- 2024-10-18 Oracle入门篇(3) oracle基础入门
- 2024-10-18 优化体系--oracle数据库I/0等待事件优化
- 2024-10-18 一文搞懂各种数据库SQL执行计划:MySQL、Oracle等
- 2024-10-18 Oracle中动态SQL详解(EXECUTE IMMEDIATE)
- 2024-10-18 「Oracle」数据库常用语句 oracle数据库常用语法
- 2024-10-18 Oracle数据库bulk collect批量绑定详解--附实例说明
- 2024-10-18 Oracle中的增、删、改和简单查询 oracle的增删改查语句
- 2024-10-18 ORACLE批量绑定FORALL与BULK COLLECT实例分享
- 2024-10-18 详解Oracle等待事件的分类、发现及优化
你 发表评论:
欢迎- 590℃几个Oracle空值处理函数 oracle处理null值的函数
- 581℃Oracle分析函数之Lag和Lead()使用
- 570℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 568℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 562℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 554℃【数据统计分析】详解Oracle分组函数之CUBE
- 540℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 536℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)