JDBC调用oracle存储过程

Java JDBC调用Oracle存储过程一般有3种: 1.无返回值 2.有一个返回值 3.返回一个数据集,就是游标! 关键字:call 语法格式{call 存储过程名(参数列表)} [color=red]1.添加员工,如果指定部门不存在,则先添加部门信息,再添加员工(无返回值) --创建存储过程如下

CREATE OR REPLACE PROCEDURE sp_add_emp1(      
    v_empno emp.empno%TYPE,      
    v_ename emp.ename%TYPE,      
    v_deptno dept.deptno%TYPE,      
    v_dname dept.dname%TYPE      
)AS     
    num1 NUMBER;      
    num2 NUMBER;      
BEGIN     
   SELECT COUNT(*) INTO num1 FROM dept WHERE deptno=v_deptno;      
IF(num1=0) THEN     
   INSERT INTO dept(deptno,dname) VALUES(v_deptno,v_dname);      
END IF;      
   SELECT COUNT(*) INTO num2 FROM emp WHERE empno=v_empno;      
IF(num2=0)THEN     
   INSERT INTO emp(empno,ename,deptno) VALUES(v_empno,v_ename,v_deptno);      
ELSE     
    raise_application_error(-202021,'员工id 重复!!!');      
END IF;      
   commit;      
     
END;     
 
CREATE OR REPLACE PROCEDURE sp_add_emp1(  
   v_empno emp.empno%TYPE,  
   v_ename emp.ename%TYPE,  
   v_deptno dept.deptno%TYPE,  
   v_dname dept.dname%TYPE  
)AS 
   num1 NUMBER;  
   num2 NUMBER;  
BEGIN 
   SELECT COUNT(*) INTO num1 FROM dept WHERE deptno=v_deptno;  
IF(num1=0) THEN 
   INSERT INTO dept(deptno,dname) VALUES(v_deptno,v_dname);  
END IF;  
   SELECT COUNT(*) INTO num2 FROM emp WHERE empno=v_empno;  
IF(num2=0)THEN 
   INSERT INTO emp(empno,ename,deptno) VALUES(v_empno,v_ename,v_deptno);  
ELSE 
   raise_application_error(-202021,'员工id 重复!!!');  
END IF;  
   commit;  
 
END; 

 

[/color] [color=red]Java中调用代码1:

[/color] 
Class.forName("oracle.jdbc.driver.OracleDriver"); 
conn = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl","scott","tiger"); 
conn.setAutoCommit(false); 
conn=DBConnection.getDBConnection().getConnection(); 
String spName="{call sp_add_emp1(?,?,?,?)}"; 
CallableStatement cstmt=conn.prepareCall(spName); c
stmt.setInt(1, 2); 
cstmt.setString(2, "wwww"); 
cstmt.setInt(3, 1);
 cstmt.setString(4, "qwqwq");
 cstmt.executeUpdate(); 
conn.close(); [color=red]

 

2.需求同上, 只是返回该部门的员工总数。(有一个返回值)[/color] --创建存储过程如下

CREATE OR REPLACE PROCEDURE sp_add_emp2( v_empno emp.empno%TYPE, v_ename emp.ename%TYPE, v_deptno dept.deptno%TYPE, v_dname dept.dname%TYPE, num out number )
AS num1 NUMBER; num2 NUMBER; 
BEGIN SELECT COUNT(*) INTO num1 FROM dept WHERE deptno=v_deptno; IF(num1=0) THEN INSERT INTO dept(deptno,dname) VALUES(v_deptno,v_dname); 
END IF; SELECT COUNT(*) INTO num2 FROM emp WHERE empno=v_empno; 
IF(num2=0)THEN INSERT INTO emp(empno,ename,deptno) VALUES(v_empno,v_ename,v_deptno); ELSE raise_application_error(-202021,'员工id 重复!!!'); 
END IF; num:=num1; 
commit; 
END; 
CREATE OR REPLACE PROCEDURE sp_add_emp2( v_empno emp.empno%TYPE, v_ename emp.ename%TYPE, 
v_deptno dept.deptno%TYPE, v_dname dept.dname%TYPE, num out number )
AS 
num1 NUMBER;
 num2 NUMBER; 
BEGIN SELECT COUNT(*) INTO num1 FROM dept WHERE deptno=v_deptno; 
IF(num1=0) THEN INSERT INTO dept(deptno,dname) VALUES(v_deptno,v_dname); 
END IF; 
SELECT COUNT(*) INTO num2 FROM emp WHERE empno=v_empno; 
IF(num2=0)THEN INSERT INTO emp(empno,ename,deptno) VALUES(v_empno,v_ename,v_deptno); 
ELSE raise_application_error(-202021,'员工id 重复!!!'); 
END IF; num:=num1; 
commit; 
END; [color=red]

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值