`

存储过程常用技巧4

阅读更多

上面的两种方式都是非常的复杂,如果仅仅是需要返回一个结果集,那就完全可以使用函数来实现了。
Java代码
create or replace package procpkg is  
   type refcursor is ref cursor;  
   procedure procrefcursor(p varchar2, p_ref_postypeList  out refcursor);  
   function procpostype(p varchar2) return PosTypeTable;   
end procpkg;  
 
create or replace package body procpkg is  
  procedure procrefcursor(p varchar2, p_ref_postypeList out  refcursor)  
  is  
    v_posTypeList PosTypeTable;  
  begin  
    v_posTypeList :=PosTypeTable();--初始化嵌套表  
    v_posTypeList.extend;  
    v_posTypeList(1) := PosType('A001','客户资料变更');  
    v_posTypeList.extend;  
    v_posTypeList(2) := PosType('A002','团体资料变更');  
    v_posTypeList.extend;  
    v_posTypeList(3) := PosType('A003','受益人变更');  
    v_posTypeList.extend;  
    v_posTypeList(4) := PosType('A004','续期交费方式变更');  
    open p_ref_postypeList for  select * from table(cast (v_posTypeList as PosTypeTable));  
  end;  
 
  function procpostype(p varchar2) return PosTypeTable  
  as  
   v_posTypeList PosTypeTable;  
  begin  
      v_posTypeList :=PosTypeTable();--初始化嵌套表  
    v_posTypeList.extend;  
    v_posTypeList(1) := PosType('A001','客户资料变更');  
    v_posTypeList.extend;  
    v_posTypeList(2) := PosType('A002','团体资料变更');  
    v_posTypeList.extend;  
    v_posTypeList(3) := PosType('A003','受益人变更');  
    v_posTypeList.extend;  
    v_posTypeList(4) := PosType('A004','续期交费方式变更');  
    return  v_posTypeList;  
  end;  
end procpkg; 

create or replace package procpkg is
   type refcursor is ref cursor;
   procedure procrefcursor(p varchar2, p_ref_postypeList  out refcursor);
   function procpostype(p varchar2) return PosTypeTable;
end procpkg;

create or replace package body procpkg is
  procedure procrefcursor(p varchar2, p_ref_postypeList out  refcursor)
  is
    v_posTypeList PosTypeTable;
  begin
    v_posTypeList :=PosTypeTable();--初始化嵌套表
    v_posTypeList.extend;
    v_posTypeList(1) := PosType('A001','客户资料变更');
    v_posTypeList.extend;
    v_posTypeList(2) := PosType('A002','团体资料变更');
    v_posTypeList.extend;
    v_posTypeList(3) := PosType('A003','受益人变更');
    v_posTypeList.extend;
    v_posTypeList(4) := PosType('A004','续期交费方式变更');
    open p_ref_postypeList for  select * from table(cast (v_posTypeList as PosTypeTable));
  end;

  function procpostype(p varchar2) return PosTypeTable
  as
   v_posTypeList PosTypeTable;
  begin
      v_posTypeList :=PosTypeTable();--初始化嵌套表
    v_posTypeList.extend;
    v_posTypeList(1) := PosType('A001','客户资料变更');
    v_posTypeList.extend;
    v_posTypeList(2) := PosType('A002','团体资料变更');
    v_posTypeList.extend;
    v_posTypeList(3) := PosType('A003','受益人变更');
    v_posTypeList.extend;
    v_posTypeList(4) := PosType('A004','续期交费方式变更');
    return  v_posTypeList;
  end;
end procpkg;
ibatis配置
Java代码
<resultMap id="posTypeResultMap" class="com.palic.elis.pos.common.dto.CodeTableItemDTO">  
   <result property="code" column="posType"/>  
   <result property="description" column="description"/>  
 </resultMap>  
 
  <select id="procPostype" resultMap="posTypeResultMap">  
    select * from table(cast (procpkg.procpostype(#value#) as PosTypeTable))  
  </select> 

<resultMap id="posTypeResultMap" class="com.palic.elis.pos.common.dto.CodeTableItemDTO">
   <result property="code" column="posType"/>
   <result property="description" column="description"/>
 </resultMap>

  <select id="procPostype" resultMap="posTypeResultMap">
    select * from table(cast (procpkg.procpostype(#value#) as PosTypeTable))
  </select>Dao的写法跟普通查询一样
Java代码
public List queryPostype() {  
  return this.getSqlMapClientTemplate().queryForList("pos_dayprocset.procPostype", null);  

public List queryPostype() {
  return this.getSqlMapClientTemplate().queryForList("pos_dayprocset.procPostype", null);
}
有几点需要注意,这里不能使用索引表,而是嵌套表。
另外就是把嵌套表强制转换为普通表。

 

分享到:
评论

相关推荐

    oracle存储过程常用技巧

    Oracle存储过程常用技巧 Oracle存储过程是一种强大的数据库对象,它可以帮助开发者简化复杂的业务逻辑,并提高数据库的安全性和性能。在 Oracle 中,存储过程是一种特殊的 PL/SQL 程序,它可以接受输入参数,执行...

    VBA常用技巧解析(全卷).zip

    本压缩包包含四卷关于VBA常用技巧的解析,每卷以独立的.exe可执行文件形式存在,这可能意味着它们是交互式的教程或演示程序,方便用户直接操作学习。 以下是一些关键的VBA知识点,这些内容可能会在这些资源中有所...

    oracle存储过程常用的一些功能

    根据提供的文件信息,以下是对Oracle存储过程常用功能的详细解读及使用技巧的总结: ### Oracle 存储过程:概述 存储过程是预先编译并存储在数据库中的SQL语句和PL/SQL代码块集合,可以在应用程序中通过名称来调用...

    oracle存储过程常用的技巧(详)

    本文将深入探讨Oracle存储过程的常用技巧,包括其基本结构、参数传递方式以及异常处理。 1. 存储过程结构 创建存储过程的基本语法如下: ```sql CREATE OR REPLACE PROCEDURE 存储过程名( 参数1 参数类型1, ...

    Windows API常用技巧汇编

    《Windows API常用技巧汇编》是一本专注于Windows操作系统编程技术的资源集合,它可能包含了光盘形式的视频讲座,旨在帮助开发者深入理解和掌握Windows API的使用。Windows API是微软为开发者提供的一个接口,通过...

    Java代码常用技巧

    ### Java代码常用技巧:Oracle数据库表操作返回值处理方法 #### 概述 在实际的软件开发工作中,处理数据库查询结果是一项常见的任务。本篇主要介绍如何利用Java语言结合Oracle数据库进行表操作,并通过示例代码...

    DB2存储过程入门实例

    4. 降低网络负载:存储过程的调用只需要传输调用信息,而非大量SQL语句。 五、存储过程的优化 1. 减少嵌套层次:过多的嵌套可能导致性能下降,应尽量简化存储过程的逻辑结构。 2. 使用索引:为WHERE子句中的列创建...

    VB常用技巧合集

    VB常用技巧合集 chm全集,比如ActiveX .Exe .Dll Server的多执行绪,ADO/DAO Bolb资料的存取,ADO/RDO Concurrency for SQL 的比较,ADO 连线的其他注意事项,ADO阶层式资料库表达,ADO设定独占性的资料库,Check两...

    C#调用存储过程

    在与SQL Server数据库打交道时,我们经常会用到存储过程,它是一种预编译的SQL语句集合,可以提高性能、简化代码并提供更好的安全性。本篇文章将详细探讨如何在C#中调用SQL Server数据库的存储过程,包括有参数和无...

    Oracle经典常用技巧荟萃

    以下是对给定文件内容中提到的Oracle常用技巧进行的详细解析。 首先,关于Oracle安装优化篇的技巧,这部分介绍了Oracle 10g RAC(Real Application Clusters)的安装,以及FreeNAS共享存储的搭建,这些是构建高可用...

    MSSQL 万能查询存储过程

    可能包含的存储过程可能涉及各种查询技巧,如联接、子查询、聚合函数、排序、分组等,以满足不同类型的查询需求。 在文件名称“查询存储过程.txt”中,我们可以推测这是文档格式,可能包含这些存储过程的详细说明、...

    PLSQL Developer 常用技巧

    ### PL/SQL Developer 常用技巧详析 PL/SQL Developer是一款专为Oracle数据库设计的强大集成开发环境(IDE),广泛应用于数据库管理、查询、存储过程编写与调试等任务。以下将详细介绍其部分核心功能及实用技巧,帮助...

    VC常用技巧总结 VC常用技巧总结 好东西VC常用技巧总结 好东西

    以上就是对VC常用技巧的总结。这些技巧不仅涵盖了基本的操作,也包括了一些高级功能,希望能帮助到正在使用Visual C++进行开发的程序员们。通过灵活运用这些技巧,可以显著提高开发效率和程序的质量。

    Sybase数据库的存储过程性能优化.pdf

    存储过程是数据库管理中常用的一种编程手段,它允许开发者编写复杂的SQL语句和控制流程,以实现特定的业务逻辑。然而,游标在存储过程中的使用虽然方便,却往往会导致性能下降。 文章指出,游标是一种逐行处理数据...

    MSSQL行列转换存储过程

    本文将深入解析MSSQL中实现行列转换的存储过程及其工作原理,帮助读者理解和掌握这一关键技术。 ### MSSQL行列转换存储过程 存储过程是SQL Server中预编译的一系列SQL语句集合,用于执行特定的数据库操作,如数据...

    如何oracle调试存储过程

    以下将详细介绍如何在Oracle环境中调试存储过程,包括调试的基本步骤、常用调试工具的使用,以及如何利用Oracle提供的调试特性来定位和解决代码中的错误。 ### Oracle存储过程调试方法 #### 1. 使用PL/SQL ...

Global site tag (gtag.js) - Google Analytics