Home > Database > Mysql Tutorial > Oracle查询所有序列 JAVA+Oracle Function全攻略

Oracle查询所有序列 JAVA+Oracle Function全攻略

WBOY
Release: 2016-06-07 17:23:12
Original
1458 people have browsed it

Oracle查询所有序列 JAVA+Oracle Function全攻略

--查看当前用户的所有序列

select SEQUENCE_OWNER,SEQUENCE_NAME from dba_sequences where sequence_owner='用户名'; 

注意事项:

    1.      必须以管理员身份登录;

    2.      sequence_owner必须为大写,不管你的用户名是否大写。只有大写才能识别。

以一张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(key varchar) return PKG_TEST.REFCURSOR is
  Result PKG_TEST.REFCURSOR;
begin
  open Result for
      select * from book where key=book.booknumber;
     
  return(Result);
end query_book;

在这个存储过程中,我们传入了查询键值key,返回了一个数据集对象
这样我们就有了一个名为query_book的存储过程,它可以返回一个结果数据集。要调用这个存储过程,可以通过CallableStatement接口来调用,,这样需要写成类似'{?=call query_book(?)}'的查询语句,并且参数和返回值都必须用代码设置;在这里,一些简单的存储过程,也可以通过查询来调用。下面就是我使用的调用方法:

public class FuncTest {
  public static void main(String[] args) throws 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);
     
      while( ret.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返回的数据集,需要进行特殊处理。

linux

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template