`
周一Monday
  • 浏览: 346744 次
  • 来自: 北京
社区版块
存档分类
最新评论

JDBC之调用存储过程

阅读更多
 --Oralce存储过程

--输入参数
 create or replace procedure insertProc
 (
	 v_deptno in dept.deptno%type,
	 v_dname in dept.dname%type,
	 v_loc in dept.loc%type
 )
 is
 begin
 	insert into dept(deptno,dname,loc) 
 	values(v_deptno,v_dname,v_loc);
 	commit;
 end;
 
--输出参数
 create or replace procedure updateProc
 (
	 v_deptno in dept.deptno%type,
	 v_dname in dept.dname%type,
	 v_loc in dept.loc%type,
	 v_result out varchar2
 )
 is
 begin
	 update dept
	 set dname=v_dname,loc=v_loc
	 where deptno=v_deptno;
	 commit;
 	v_result:='update success';
 end;

 

 

package org.monday.demo;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.SQLException;

import org.junit.Test;
import org.monday.util.JdbcUtil;

public class ProcMain {

	@Test
	public void test_insert() {
		String proc = "{call insertProc (?,?,?)}"; // 要调用的存储过程
		Connection conn = null;
		CallableStatement cstmt = null;
		try {
			conn = JdbcUtil.getConnection();
			// 调用存储过程
			cstmt = conn.prepareCall(proc);
			// 为输入参数赋值
			cstmt.setInt(1, 70);
			cstmt.setString(2, "web");
			cstmt.setString(3, "chengdu");
			// 执行
			cstmt.executeUpdate();
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			JdbcUtil.release(conn, cstmt, null);
		}
	}

	@Test
	public void test_update() {
		String proc = "{call updateProc (?,?,?,?)}"; // 要调用的存储过程
		Connection conn = null;
		CallableStatement cstmt = null;
		try {
			conn = JdbcUtil.getConnection();
			// 调用存储过程
			cstmt = conn.prepareCall(proc);
			// 为输入参数赋值
			cstmt.setInt(1, 70);
			cstmt.setString(2, "jdbc");
			cstmt.setString(3, "guangzhou");
			// 注册输出参数
			cstmt.registerOutParameter(4, java.sql.Types.VARCHAR);
			// cstmt.registerOutParameter(4, java.sql.Types.VARCHAR, "v_result");
			// 执行
			cstmt.executeUpdate();
			// 获取返回信息
			System.out.println(cstmt.getString(4));
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			JdbcUtil.release(conn, cstmt, null);
		}
	}
}

 

分享到:
评论

相关推荐

    JDBC 调用存储过程方法

    本篇文章将深入探讨如何使用JDBC调用存储过程。 首先,存储过程是预编译的SQL代码集合,它们封装在数据库中,可以接收输入参数,处理数据,然后返回结果或输出参数。存储过程在提高性能、增强安全性和简化复杂操作...

    JDBC调用存储过程

    本文将详细讲解如何使用JDBC来调用存储过程,以实现数据的增删改查操作。 首先,理解存储过程是数据库中的一个重要概念。存储过程是一组预先编译好的SQL语句集合,它可以包含控制流语句、输入/输出参数,甚至可以有...

    JDBC存储过程的调用

    JDBC存储过程的调用

    JDBC调用MySQL5存储过程[文].pdf

    在软件开发中,JDBC...尽管JDBC调用存储过程相对简单,但设计和开发存储过程本身可能需要更深入的数据库知识和SQL编程技巧。在实际应用中,存储过程可以提高性能,封装复杂的业务逻辑,并提供数据库层面的安全性。

    jdbc调用存储过程

    使用jdbc调用存储过程的代码示例 调用数据库连接池

    Spring JdbcTemplate调用Oracle存储过程实现CRUD

    对于 `P_EMP_SELECT` 存储过程,我们使用 `CallableStatementCallback` 对象调用存储过程,并将结果集处理到 `List` 集合中。 对于 `P_EMP_ADD` 存储过程,我们使用 `CallableStatementCallback` 对象调用存储过程...

    jdbc调用存储过程实现增删改查

    ### JDBC调用存储过程 1. **加载驱动**:使用`Class.forName()`方法加载Oracle的JDBC驱动,例如`oracle.jdbc.driver.OracleDriver`。 2. **建立连接**:通过`DriverManager.getConnection()`方法获取数据库连接。 3....

    jdbc调用存储过程 函数例子

    本文将详细阐述如何通过JDBC在Java程序中调用存储过程和函数,并提供一个实际的例子。 ### 1. JDBC概述 JDBC是Java API,它提供了统一的接口来访问不同类型的数据库。通过JDBC,开发者可以进行数据库连接、执行SQL...

    JDBC存储过程调用示例

    JDBC存储过程调用示例,详细描述了存储过程调用的过程。

    jdbc调用存储过程,函数,游标

    本篇文章将详细讲解如何利用JDBC调用存储过程、函数以及处理游标。 首先,存储过程是数据库中预编译的一组SQL语句,它允许我们封装复杂的业务逻辑,提高执行效率,减少网络传输的数据量。在JDBC中调用存储过程通常...

    jdbc执行存储过程

    在给定的代码片段中,我们可以看到一个典型的使用JDBC调用存储过程的例子。下面,我们将分步骤解析这段代码: 1. **加载JDBC驱动**: ```java try{ Class.forName(...

    java调用存储过程(含out参数)

    3. **准备CallableStatement**:对于调用存储过程,我们需要使用`CallableStatement`对象,它是`PreparedStatement`的子类,专门用于调用数据库存储过程。通过`Connection`对象的`prepareCall()`方法创建。 4. **...

    java 调用存储过程

    在Java编程中,调用存储过程是连接数据库并执行预定义SQL代码的一种常见方式。存储过程是由数据库管理系统(如MySQL, Oracle, SQL Server等)编译并存储的一组操作,可以包含复杂的逻辑、条件判断、循环等,提高数据...

    JDBC调DB2存储过程

    ### JDBC调用DB2存储过程详解 在Java开发过程中,经常需要通过JDBC(Java Database Connectivity)技术来访问数据库中的数据。本篇文章将详细介绍如何利用JDBC调用DB2数据库中的存储过程,并对代码进行逐行解析,...

    31.jdbc调用存储过程?.avi

    jdbc调用存储过程?.avi

    JDBC调用存储过程的小例子

    在这个“JDBC调用存储过程的小例子”中,我们将探讨如何使用JDBC来执行数据库中的存储过程,这是一个非常实用的功能,特别是在处理复杂的业务逻辑或批量数据操作时。 首先,我们需要了解什么是存储过程。存储过程是...

    PLSQL jdbc调用存储过程(入门)

    PLSQL jdbc调用存储过程(入门)

    birt调用存储过程

    BIRT使用JDBC的存储过程SQL转义语法来调用存储过程。调用方式分为两种: - **带返回值的调用**:适用于返回单个结果集或特定值的存储过程。 - **不带返回值的调用**:主要用于执行那些不返回数据,但可能改变...

Global site tag (gtag.js) - Google Analytics