`
javaEEdevelop
  • 浏览: 876488 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

java 中调用存储过程

 
阅读更多
Statement    //stmt

PreparedStatement  //pstmt

CallableStatement    //cstmt

上面三个都可以,但是区别,我认为

Statement //既不能带进参数,也没有带出参数

 stmt=con.createStatement();	//得到Statement对象

stmt.execute("call sp_test(1)");

PreparedStatement //只能带进,不能带出

pstmt=con.prepareStatement("call sp_test(?)");  //得到PreparedStatement对象

pstmt.setInt(1, 10);  //PreparedStatement带进第一个int参数 值等于10

pstmt.execute();  //执行


CallableStatement  //既能带进参数,也能带出参数 

cstmt=con.prepareCall("call  sp_test(?,?,?);");	  //得到CallableStatement对象

cstmt.setInt(1, 10);   //CallableStatement带进第一个int参数 值等于10

//CallableStatement带出第一个VARCHAR类型和第二个INTEGER的参数 

cstmt.registerOutParameter(2, java.sql.Types.VARCHAR,10);

cstmt.registerOutParameter(3, java.sql.Types.INTEGER); 

stmt.execute();  //执行

//获取用cstmt.getString(2)来获取cstmt.registerOutParameter(2, java.sql.Types.INTEGER,10);返回的数据
Integer id=cstmt.getInteger(2);

//获取用cstmt.getInt(3)来获取cstmt.registerOutParameter(3, java.sql.Types.VARCHAR);返回的数据
//如果是varchar类型的话
String id=cstmt.getString(3);
 
游标的使用,返回结果集的存储过程
--定义一个包,在再里面定义一个游标类型的user_cursor变量
create or replace package pck_users as
type user_cursor is ref cursor;
end   pck_users;
--创建存储过程
 create or replace procedure sp_users(status in number, p_cursor out pck_users.user_cursor) is
 --定义部分
 begin
  --执行部分
   open   p_cursor for select * from user  u where u.status=status;--赋值给游标类型p_cursor
   close  sp_user;关闭游标
 end;
 //java中调用
CallableStatement cs=con.prepareCall("call sp_users(?,?)");//调用sp_users 存储过程
//赋值
cstmt.setInt(1, 10);  
cstmt.registerOutParameter(2, oracle.jdbc.OracleTypes.CURSOR);
cs.execute();//执行

ResultSet rs= (ResultSet)cs.getObject(2); //强制转换 

while(rs.next()){
	String username=rs.getString(1);
	String password=rs.getString(2);
}

//关闭资源
rs.close();
cs.close();
conn.close();
 





分享到:
评论

相关推荐

    java中调用存储过程

    在Java中调用存储过程是实现数据库操作的一种高级方法,特别是在处理复杂的业务逻辑或需要执行大量数据更新的情况下。本文将详细解析如何在Java应用程序中调用Oracle数据库中的存储过程,并解释如何传递参数以及接收...

    jAVA中调用存储过程

    在Java中调用存储过程是实现数据库操作的一种高级方法,特别是在处理复杂的业务逻辑或执行大量数据更新时。本文将深入探讨如何在Java中调用Oracle数据库的存储过程,并通过两个具体的示例进行详细讲解。 ### Java...

    在Java中调用存储过程详解

    本文将深入探讨如何在Java中调用存储过程,并通过实例进行讲解。 一、存储过程概述 存储过程是数据库中预编译的SQL语句集合,可以包含多个SQL语句和控制流程结构,如条件判断、循环等。它们提供了提高性能、减少...

    Java中调用存储过程或存储函数的方法[文].pdf

    最后,为了调试和测试存储过程和存储函数,你可以创建一个简单的测试程序,编写相应的存储过程和存储函数,然后使用上述Java代码进行调用,观察结果是否符合预期。记住,在编写和调用存储过程或存储函数时,一定要...

    jsp中调用存储过程的方法

    有时,我们需要在JSP中调用数据库的存储过程以执行特定的业务逻辑。存储过程是预编译的SQL语句集合,可以在数据库中高效地执行。本文将详细介绍如何在JSP中调用存储过程,并提供一个简单示例。 首先,我们需要了解...

    java 调用db2存储过程

    要在 Java 中调用带有输入参数的存储过程,需要使用 CallableStatement 对象,并将输入参数传递给存储过程。例如: ```java CallableStatement cs = conn.prepareCall("call insql(?)"); cs.setString(1, "A00"); cs...

    java 调用存储过程

    下面将详细阐述如何在Java中调用存储过程。 首先,要调用存储过程,你需要确保已正确地在Java应用程序中建立了与数据库的连接。这通常通过JDBC(Java Database Connectivity)实现,它提供了一组API来与各种数据库...

    JAVA调用ORACLE存储过程

    在 Java 中调用存储过程 接下来,在 Java 中调用上述存储过程,实现如下: ```java public class TestProcedure { Connection conn = null; CallableStatement cstmt = null; String url = "jdbc:oracle:thin:@...

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

    Java中调用存储过程主要通过JDBC(Java Database Connectivity)接口实现。以下是一步步的操作步骤: 1. **加载数据库驱动**:首先,确保已添加对应数据库的JDBC驱动库到项目类路径中,如MySQL的`mysql-connector-...

    java调用存储过程小结.pdf

    在 Java 中调用存储过程需要使用 JDBC 连接发送给 DBMS,执行存储过程并返回结果。下面是一个简单的示例代码,演示如何在 Java 中调用 Oracle 存储过程: ```java public class TestProcedure { Connection conn=...

    java 调存储过程

    下面将详细阐述如何在Java中调用存储过程,以及涉及的参数输入输出。 1. **JDBC接口调用存储过程** Java通过Java Database Connectivity (JDBC) API与数据库进行交互。要调用存储过程,首先需要建立数据库连接,...

    java中存储过程的使用

    在Java中调用存储过程的示例代码如下: ```java public static void main(String[] args) { try { Class.forName("oracle.jdbc.driver.OracleDriver"); Connection con = DriverManager.getConnection("jdbc:...

    Java调用存储过程的2种方法

    在Java中调用数据库中的存储过程是常见的操作之一,这不仅可以提高程序性能和代码可维护性,还可以更好地利用数据库的功能。根据提供的标题、描述以及部分内容,本文将详细介绍Java中调用存储过程的两种方法。 ####...

    java调用存储过程源码 sql数据库

    在Java中调用存储过程主要通过JDBC(Java Database Connectivity)接口实现。以下是一个基本的步骤: 1. **加载驱动**:首先,你需要加载对应数据库的JDBC驱动。例如,如果你使用的是MySQL,你可能需要`Class.for...

    一个java调用存储过程的示例项目

    在Java中调用存储过程通常涉及以下步骤: 1. 加载数据库驱动:根据所使用的数据库类型(如MySQL、Oracle、SQL Server等),需要导入相应的JDBC驱动库,并使用`Class.forName()`方法加载驱动。 2. 建立连接:使用`...

    java调用存储过程返回数组

    本文将详细探讨如何在Java中调用存储过程,并处理返回的数组类型数据。 首先,存储过程是一种预编译的SQL语句集合,它可以包含多个SQL操作,变量、条件判断、循环等控制结构。在Oracle数据库中,可以创建一个存储...

    java调用存储过程

    本文将深入探讨如何在Java中调用存储过程,以及这背后涉及的相关技术点。 首先,理解存储过程的基本概念至关重要。存储过程是由数据库管理系统(如MySQL、Oracle、SQL Server等)支持的,它允许开发者编写一系列...

    Java调用存储过程(包含游标的)两种方法

    这是自己这段时间学习Oracle数据库的一些有关存储过程和Java中调用存储过程的学习心得。

    java调用Oracle存储过程

    在Java中调用存储过程主要通过`CallableStatement`接口实现,它是`PreparedStatement`的子接口,专用于调用存储过程和函数。 以下是一个基本的步骤来调用Oracle存储过程: 1. **建立数据库连接**: 使用`...

Global site tag (gtag.js) - Google Analytics