JAVA调用增删改的存储过程

 

1、创建添加存储过程

   
   
CREATE OR REPLACE PROCEDURE stu_proc(v_id IN NUMBER , v_name IN VARCHAR2 , v_age IN NUMBER ) AS BEGIN INSERT INTO student(id, sname, age) values (v_id, v_name, v_age); commit ; END ;

     

JAVA调用添加存储过程

   
   
package com.ljq.test; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.SQLException; public class ProceTest { public static void main(String[] args) throws Exception { Connection conn = null ; CallableStatement statement = null ; String sql = " {call stu_proc(?, ?, ?)} " ; try { conn = ConnUtils.getConnection(); statement = conn.prepareCall(sql); statement.setInt( 1 , 6 ); statement.setString( 2 , " laoli " ); statement.setInt( 3 , 45 ); // 如果第一个结果是ResultSet对象,则返回true;
如果第一个结果是更新、添加、修改或者没有结果,则返回 false boolean issuccess = statement.execute(); // 成功返回true,失败返回false System.out.println(issuccess); } catch (SQLException e) { e.printStackTrace(); } finally { ConnUtils.free( null , statement, conn); } } }

            

创建删除存储过程语句

   
   
CREATE OR REPLACE PROCEDURE stu_proc(v_id IN NUMBER , v_msg OUT VARCHAR2 ) IS v_flag NUMBER : = 1 ; BEGIN SELECT o.id INTO v_flag FROM student o WHERE o.id = v_id; DELETE FROM student o WHERE o.id = v_flag; commit ; v_msg: = ' 删除成功 ' ; EXCEPTION WHEN OTHERS THEN v_msg: = ' 删除失败 ' ; END ;

 

java调用删除存储过程

   
   
package com.ljq.test; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.SQLException; import java.sql.Types; public class ProceTest { public static void main(String[] args) throws Exception { Connection conn = null ; CallableStatement statement = null ; String sql = " {call stu_proc(?, ?)} " ; try { conn = ConnUtils.getConnection(); statement = conn.prepareCall(sql); statement.setInt( 1 , 4 ); statement.registerOutParameter( 2 , Types.VARCHAR); statement.execute(); String msg = statement.getString( 2 ); System.out.println(msg); } catch (SQLException e) { e.printStackTrace(); } finally { ConnUtils.free( null , statement, conn); } } }

          

创建修改存储过程

   
   
CREATE OR REPLACE PROCEDURE stu_proc ( v_id IN NUMBER , v_name IN VARCHAR2 , v_msg OUT VARCHAR2 ) AS v_flag number ; BEGIN SELECT o.id INTO v_flag FROM student o WHERE o.id = v_id; UPDATE student o SET o.sname = v_name WHERE o.id = v_id; commit ; v_msg: = ' 修改成功 ' ; EXCEPTION WHEN OTHERS THEN v_msg: = ' 修改失败 ' ; END ;

         

java调用修改存储过程

   
   
package com.ljq.test; import java.sql.CallableStatement; import java.sql.Connection; import java.sql.SQLException; import java.sql.Types; public class ProceTest { public static void main(String[] args) throws Exception { Connection conn = null ; CallableStatement statement = null ; String sql = " {call stu_proc(?, ?, ?)} " ; try { conn = ConnUtils.getConnection(); statement = conn.prepareCall(sql); statement.setInt( 1 , 3 ); statement.setString( 2 , " laoli " ); statement.registerOutParameter( 3 , Types.VARCHAR); statement.execute(); String msg = statement.getString( 3 ); System.out.println(msg); } catch (SQLException e) { e.printStackTrace(); } finally { ConnUtils.free( null , statement, conn); } } }
 
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值