`
huibin
  • 浏览: 740397 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

Oracle JDBC 获取 Function返回的结果集

阅读更多
前几天项目里数据存储支持了存储过程,当时赶进度,只是简单的拿SQL Server 2000做了测试。今天同事要用Oracle9i数据库,于是研究了一下Oracle的存储过程,不看不知道啊,居然Oracle里要支持存储过程如此复杂!!上网查资料,自己做实验,终于弄了大半夜才鼓捣出来!
 
项目里的需求很简单:通过一个存储过程返回一个数据集(当然,我只负责简单调用存储过程,存储过程内部可能很复杂了^_^)。不同于SQL Server 2000的存储过程,Oracle里的存储过程分为procedure和function两种,如果用procedure的话,无法直接返回结果集,读取结果集的方式比较复杂;function是可以返回结果集的存储过程,调用相对简单些。
 
下面的介绍将以一张BOOK表的查询为例:
create table BOOK
(
  BOOKNUMBER CHAR(3) not null,
  BOOKNAME   VARCHAR2(50),
  BOOKPRICE  NUMBER(18,2)
)
 
要返回数据集,就需要使用Oracle里的reference cursor类型,不过Oracle里这个类型用的方式比较罗唆(搞不明白Oracle为什么要弄的这么复杂),首先要声明一个引用的cursor类型,这个通过创建一个包来实现:
CREATE OR REPLACE PACKAGE PKG_TEST
AS
    TYPE REFCURSOR IS REF CURSOR;
END PKG_TEST;
 
然后创建我们的function存储过程:
create or replace function query_book(book_no varchar) return PKG_TEST.REFCURSOR is
  Result PKG_TEST.REFCURSOR;
begin
  open Result for
       select * from book where book_no =book.booknumber;
      
  return(Result);
end query_book;
在这个存储过程中,我们传入了查询键值key,返回了一个数据集对象
 
这样我们就有了一个名为query_book的存储过程,它可以返回一个结果数据集。要调用这个存储过程,可以通过CallableStatement接口来调用,这样需要写成类似'{?=call query_book(?)}'的查询语句,并且参数和返回值都必须用代码设置;在这里,一些简单的存储过程,也可以通过查询来调用。下面就是我使用的调用方法:
public class FuncTest {
  public static void main(String[] argsthrows Exception {
    Class.forName("oracle.jdbc.driver.OracleDriver");
    Connection  connection = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:LeeDB"
        "TEST""test");
    Statement  stmt = connection.createStatement();
    ResultSet  dataset = stmt.executeQuery("SELECT query_book('001') FROM DUAL");
    if (dataset.next()) {
      ResultSet  ret = (ResultSet)dataset.getObject(1);
      
      whileret.next() ) {
        System.out.print(ret.getString(1));
        System.out.print("\t");
        System.out.print(ret.getString(2));
        System.out.print("\t");
        System.out.println(ret.getDouble(3));
      
    }
  }
}
注意这里返回的数据集中内嵌了function返回的数据集,需要进行特殊处理。
 
上面代码执行之后可以成功返回结果:
001 Pascal编程 20.0
分享到:
评论

相关推荐

    Oracle函数_JDBC常用写法

    Oracle函数_JDBC常用写法

    Oracle sqldeveloper without jdk (win+linux)

    Oracle SQL Developer, v1.5.0.54.40 Release Notes 完整版下载:http://www.oracle.com/technology/global/cn/software/products/sql/index.html 1. Known Issues 1.1 General - Print prints only one page ...

    hibernate.properties

    #hibernate.connection.driver_class oracle.jdbc.driver.OracleDriver #hibernate.connection.username ora #hibernate.connection.password ora #hibernate.connection.url jdbc:oracle:thin:@localhost:1521:orcl...

    FCKEDIT和定时器

    driverClassName="oracle.jdbc.driver.OracleDriver" url="jdbc:oracle:thin:@127.0.0.1:1521:ora9"/> <Resource name="jdbc/mysqlds" auth="Container" type="javax.sql.DataSource" maxActive...

    基于J2EE框架的个人博客系统项目毕业设计论文(源码和论文)

    而越来越多专业知识的 Blog 的出现,让我们看到了 Blog 更多所蕴涵的巨大的信息价值:不同的 Blog 选择不同的内容,收集和整理成为很多人关注的专业 Blog ——目前越来越多的人获取信息的来源是一些固定的 Blog 。...

    Spring中文帮助文档

    11.5.9. 使用SimpleJdbcCall返回的ResultSet/REF Cursor 11.6. 用Java对象来表达JDBC操作 11.6.1. SqlQuery类 11.6.2. MappingSqlQuery类 11.6.3. SqlUpdate类 11.6.4. StoredProcedure类 11.6.5. SqlFunction...

    Spring API

    11.5.9. 使用SimpleJdbcCall返回的ResultSet/REF Cursor 11.6. 用Java对象来表达JDBC操作 11.6.1. SqlQuery类 11.6.2. MappingSqlQuery类 11.6.3. SqlUpdate类 11.6.4. StoredProcedure类 11.6.5. SqlFunction...

    Java/JavaEE 学习笔记

    第五章 Group Function(组函数)......130 第六章 Sub queries(子查询)............132 第七章 指定运行时变量..................133 第八章 数据模型和数据库设计......134 第九章 Creating Tables(创建表)......135...

    Java学习笔记-个人整理的

    {13.10}可滚动结果集}{201}{section.13.10} {13.11}Procedure}{201}{section.13.11} {14}xml}{204}{chapter.14} {14.1}元素}{204}{section.14.1} {14.2}XML的设计}{205}{section.14.2} {14.3}DTD/Schema}{205}...

    J2EE学习笔记(J2ee初学者必备手册)

    第五章 Group Function(组函数)......130 第六章 Sub queries(子查询)............132 第七章 指定运行时变量..................133 第八章 数据模型和数据库设计......134 第九章 Creating Tables(创建表)......135...

    Geotools Java API 开发gis的参考资料

    org.geotools.data.jdbc.attributeio org.geotools.data.jdbc.datasource org.geotools.data.jdbc.fidmapper org.geotools.data.jdbc.referencing org.geotools.data.memory org.geotools.data.mif org.geo...

    Spring-Reference_zh_CN(Spring中文参考手册)

    5.4.1. 设置和获取属性值以及嵌套属性 5.4.2. 内建的PropertyEditor实现 5.4.2.1. 注册用户自定义的PropertyEditor 6. 使用Spring进行面向切面编程(AOP) 6.1. 简介 6.1.1. AOP概念 6.1.2. Spring AOP的功能和目标 ...

    Spring 2.0 开发参考手册

    5.4.1. 设置和获取属性值以及嵌套属性 5.4.2. 内建的PropertyEditor实现 6. 使用Spring进行面向切面编程(AOP) 6.1. 简介 6.1.1. AOP概念 6.1.2. Spring AOP的功能和目标 6.1.3. Spring的AOP代理 6.2. @...

    spring chm文档

    5.4.1. 设置和获取属性值以及嵌套属性 5.4.2. 内建的PropertyEditor实现 6. 使用Spring进行面向切面编程(AOP) 6.1. 简介 6.1.1. AOP概念 6.1.2. Spring AOP的功能和目标 6.1.3. Spring的AOP代理 6.2. @...

    梦想新闻发布系统-正式版

    |-------|-------|--|--Function.java 常用方法定义类源文件 |-------|-------|--|--ListClass.java 前台类别显示类源文件 |-------|-------|--|--Log.java 日志类源文件 |-------|-------|--|--Login.java 用户登录...

    金蝶BOSV6.1_业务组件API参考手册

    com.kingdee.bos.jdbc.trace com.kingdee.bos.kscript com.kingdee.bos.kscript.adapter com.kingdee.bos.kscript.dom com.kingdee.bos.kscript.dom.expr com.kingdee.bos.kscript.dom.stmt ...

    Geoserver用户手册

    7.7 Oracle Georaster . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177 7.8 Postgis Raster . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ...

    spring-framework-reference4.1.4

    Not Using Commons Logging ................................................................... 12 Using SLF4J ..............................................................................................

    spring-framework-reference-4.1.2

    Not Using Commons Logging ................................................................... 12 Using SLF4J ..............................................................................................

Global site tag (gtag.js) - Google Analytics