JDBC 调用 存储过程

一、无返回值的存储过程

PROC :

create or replace procedure insert_user(

        username in varchar2,

        userpassword in varchar2 )

as

begin  

insert into userInfo values(wepull_books.nextval,username,userpassword);

end insert_user;

在java里调用时就用下面的代码:

 CallableStatement cst = con.prepareCall("{call insert_user(?,?) }");   

//设置两个问号的值   

cst.setString(1, "zhangxuan");   

cst.setString(2, "123");   

//执行SQL语句   

cst.execute();   

con.close();

二:有返回值的存储过程(非列表)

存储过程

create or replace procedure check_user(

        username in varchar2,

        userpassword in varchar2,

        userCount out integer )

as

begin

   select  count(*) into userCount from userInfo where uname=username and password=userpassword;

end check_user;

java代码

// 设置要执行的SQL语句,如果是执行存储过程,那么执行存储过程的格式按括号内所示   

CallableStatement cst = con.prepareCall("{call check_user(?,?,?) }");

// 设置存储过程中两个输入参数的值   

cst.setString(1, "zhangxuan");   

cst.setString(2, "123");   

// 设置存储过程中输出参数的值   

cst.registerOutParameter(3, Types.INTEGER);   

// 执行SQL语句   

cst.execute();   

// 执行完存储过程后,取得存储过程中输出参数的值   

int testPrint = cst.getInt(3);   

System.out.println(testPrint);

注意 :

这里的cst.getInt(3) ;并不是随意写的3而是这里的out参数在第三个位置,如果在第二个位置,则cst.getInt(2);依次类推。

三:返回列表 

由于oracle存储过程没有返回值,它的所有返回值都是通过out参数来替代的,列表同样也不例外,但由于是集合,所以不能用一般的参数,必须要用pagkage了.所以要分两部分。

1, 建一个程序包。如下:

CREATE OR REPLACE PACKAGE TESTPACKAGE 

AS 

TYPE Test_CURSOR IS REF CURSOR;

end TESTPACKAGE;

2,建立存储过程,存储过程为:

CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR)

 IS

BEGIN 

    OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;

END TESTC;

可以看到,它是把游标(可以理解为一个指针),作为一个out 参数来返回值的。

java代码 :

CallableStatement proc = null;      

proc = conn.prepareCall("{ call hyq.testc(?) }");      

proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);      

proc.execute();      

rs = (ResultSet)proc.getObject(1)

 while(rs.next())      

{

           System.out.println("<tr><td>" + rs.getString(1) + "</td><td>"+rs.getString(2)+"</td></tr>"); 

}      

猜你喜欢

转载自gamewong.iteye.com/blog/1675043