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); } } }