ホームページ > データベース > mysql チュートリアル > Oracle中的存储过程在pl/sql和java中如何调用

Oracle中的存储过程在pl/sql和java中如何调用

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-07 16:57:36
オリジナル
1477 人が閲覧しました

案例:添加学生,然后返回该班级的所有学生。create or replace procedure add_stu(p_sid stu.sid%type, p_sname stu.sn

案例:添加学生,然后返回该班级的所有学生。

create or replace procedure add_stu(
p_sid stu.sid%type,        
p_sname stu.sname%type,
p_cid stu.cid%type,
p_data out sys_refcursor     -- 输出变量,系统引用游标
)
as
begin
   insert into stu(sid,sname,cid)
   values(p_sid,p_sname,p_cid);
   commit;
 
   --将查询的结果集的地址放到引用游标变量中,,再传递出去
   open p_data for select * from stu where cid=p_cid;
 
end;


--PL/SQL 调用
declare
  stu_data sys_refcursor;
  stu_row stu%rowtype;
begin
  add_stu(52,'b',1,stu_data);
  fetch stu_data into stu_row;
  while(stu_data%found)
  loop
     dbms_output.put_line(stu_row.sname);
     fetch stu_data into stu_row;
  end loop;
  close stu_data;
end;

 

--java中调用
CallableStatement cstmt = null;
String spName = “{call add_stu(?,?,?,?)}";
cstmt = conn.prepareCall(spName);
cstmt.setInt(1, 工号);
 …………
cstmt.registerOutParameter(4, Oracle.jdbc.OracleTypes.CURSOR);   --设置第4个问号的值
cstmt.executeUpdate();
ResultSet rs = (ResultSet)cstmt.getObject(4);

linux

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート