oracle 行转列数据量太大报错

2024-06-23 11:32
文章标签 oracle 报错 转列 数据量

本文主要是介绍oracle 行转列数据量太大报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

wmsys.wm_concat  这个函数存在缺陷,数据量大的时候,容易报ora-22813

    没办法只能通过重新定义一个行转列函数,copy了一下 http://www.savedba.com/?p=955  这个人写的函数

有点问题,自己又改了下。

drop type t_dj_concat;
drop function dj_concat;


create or replace type t_dj_concat  as object
(
  curr_str clob,
  static function odciaggregateinitialize(sctx in out t_dj_concat)
    return number,
  member function odciaggregateiterate(self in out t_dj_concat,
                                       p1   in varchar2) return number,
  member function odciaggregateterminate(self        in t_dj_concat,
                                         returnvalue out clob,
                                         flags       in number)
    return number,
  member function odciaggregatemerge(self  in out t_dj_concat,
                                     sctx2 in t_dj_concat) return number
);
/




create or replace type body t_dj_concat
is
  static function odciaggregateinitialize(sctx in out t_dj_concat)
  return number
  is
  begin
  sctx := t_dj_concat(null) ;
  return odciconst.success;
  end;
  member function odciaggregateiterate(self in out t_dj_concat,


  p1 in varchar2)
  return number
  is
  begin
  if(curr_str is not null) then
  curr_str := curr_str || ',' || p1;
  else
  curr_str := p1;
  end if;
  return odciconst.success;
  end;
  member function odciaggregateterminate(self in t_dj_concat,
  returnvalue out clob,
  flags in number)
  return number
  is
  begin
  returnvalue := curr_str ;
  return odciconst.success;
  end;
  member function odciaggregatemerge(self in out t_dj_concat,
  sctx2 in t_dj_concat)
  return number
  is
  begin
  if(sctx2.curr_str is not null) then
  self.curr_str := self.curr_str || ',' || sctx2.curr_str ;
  end if;
  return odciconst.success;
  end;
end;
/






create or replace function dj_concat(p1 varchar2)
return clob aggregate using t_dj_concat ;
/


然后测试完美解决

 sb.append(" select  rptcode,infcode,rowcode,colcode,nullable,infname,dj_concat(infvalue) as infvalue  from  CCISDIC    group ");
       sb.append(" by rptcode,infcode,rowcode,colcode,nullable,infname ");
       return this.getJdbcService().findForList(sb.toString(),new Object[]{});

 String value=map.get("infvalue").toString();

这篇关于oracle 行转列数据量太大报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087029

相关文章

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla

ORACLE 11g 创建数据库时 Enterprise Manager配置失败的解决办法 无法打开OEM的解决办法

在win7 64位系统下安装oracle11g,在使用Database configuration Assistant创建数据库时,在创建到85%的时候报错,错误如下: 解决办法: 在listener.ora中增加对BlueAeri-PC或ip地址的侦听,具体步骤如下: 1.启动Net Manager,在“监听程序”--Listener下添加一个地址,主机名写计

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当

Jenkins 插件 地址证书报错问题解决思路

问题提示摘要: SunCertPathBuilderException: unable to find valid certification path to requested target...... 网上很多的解决方式是更新站点的地址,我这里修改了一个日本的地址(清华镜像也好),其实发现是解决不了上述的报错问题的,其实,最终拉去插件的时候,会提示证书的问题,几经周折找到了其中一遍博文

oracle分页和mysql分页

mysql 分页 --查前5 数据select * from table_name limit 0,5 select * from table_name limit 5 --limit关键字的用法:LIMIT [offset,] rows--offset指定要返回的第一行的偏移量,rows第二个指定返回行的最大数目。初始行的偏移量是0(不是1)。   oracle 分页 --查前1-9

【Python报错已解决】AttributeError: ‘list‘ object has no attribute ‘text‘

🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 前言一、问题描述1.1 报错示例1.2 报错分析1.3 解决思路 二、解决方法2.1 方法一:检查属性名2.2 步骤二:访问列表元素的属性 三、其他解决方法四、总结 前言 在Python编程中,属性错误(At

DBeaver 连接 MySQL 报错 Public Key Retrieval is not allowed

DBeaver 连接 MySQL 报错 Public Key Retrieval is not allowed 文章目录 DBeaver 连接 MySQL 报错 Public Key Retrieval is not allowed问题解决办法 问题 使用 DBeaver 连接 MySQL 数据库的时候, 一直报错下面的错误 Public Key Retrieval is

vue 父组件调用子组件的方法报错,“TypeError: Cannot read property ‘subDialogRef‘ of undefined“

vue 父组件调用子组件的方法报错,“TypeError: Cannot read property ‘subDialogRef’ of undefined” 最近用vue做的一个界面,引入了一个子组件,在父组件中调用子组件的方法时,报错提示: [Vue warn]: Error in v-on handler: “TypeError: Cannot read property ‘methods

ORACLE语法-包(package)、存储过程(procedure)、游标(cursor)以及java对Result结果集的处理

陈科肇 示例: 包规范 CREATE OR REPLACE PACKAGE PACK_WMS_YX IS-- Author : CKZ-- Created : 2015/8/28 9:52:29-- Purpose : 同步数据-- Public type declarations,游标 退休订单TYPE retCursor IS REF CURSOR;-- RETURN vi_co_co

Oracle主键和外键详解及实用技巧

在 Oracle 数据库中,主键(Primary Key)和外键(Foreign Key)用于维护数据库表之间的数据完整性。 1. 主键(Primary Key) 主键是一列或多列,能够唯一标识表中的每一行。表中只能有一个主键,并且主键列不能为空(即 NOT NULL)。 特性: 唯一性:主键中的每一个值都是唯一的,不能重复。非空性:主键列不能包含 NULL 值。索引:Oracle 自动为