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应用程序中调用Oracle数据库中的存储过程,并解释如何传递参数以及接收...
在Java中调用存储过程是实现数据库操作的一种高级方法,特别是在处理复杂的业务逻辑或执行大量数据更新时。本文将深入探讨如何在Java中调用Oracle数据库的存储过程,并通过两个具体的示例进行详细讲解。 ### Java...
本文将深入探讨如何在Java中调用存储过程,并通过实例进行讲解。 一、存储过程概述 存储过程是数据库中预编译的SQL语句集合,可以包含多个SQL语句和控制流程结构,如条件判断、循环等。它们提供了提高性能、减少...
最后,为了调试和测试存储过程和存储函数,你可以创建一个简单的测试程序,编写相应的存储过程和存储函数,然后使用上述Java代码进行调用,观察结果是否符合预期。记住,在编写和调用存储过程或存储函数时,一定要...
有时,我们需要在JSP中调用数据库的存储过程以执行特定的业务逻辑。存储过程是预编译的SQL语句集合,可以在数据库中高效地执行。本文将详细介绍如何在JSP中调用存储过程,并提供一个简单示例。 首先,我们需要了解...
要在 Java 中调用带有输入参数的存储过程,需要使用 CallableStatement 对象,并将输入参数传递给存储过程。例如: ```java CallableStatement cs = conn.prepareCall("call insql(?)"); cs.setString(1, "A00"); cs...
下面将详细阐述如何在Java中调用存储过程。 首先,要调用存储过程,你需要确保已正确地在Java应用程序中建立了与数据库的连接。这通常通过JDBC(Java Database Connectivity)实现,它提供了一组API来与各种数据库...
在 Java 中调用存储过程 接下来,在 Java 中调用上述存储过程,实现如下: ```java public class TestProcedure { Connection conn = null; CallableStatement cstmt = null; String url = "jdbc:oracle:thin:@...
Java中调用存储过程主要通过JDBC(Java Database Connectivity)接口实现。以下是一步步的操作步骤: 1. **加载数据库驱动**:首先,确保已添加对应数据库的JDBC驱动库到项目类路径中,如MySQL的`mysql-connector-...
在 Java 中调用存储过程需要使用 JDBC 连接发送给 DBMS,执行存储过程并返回结果。下面是一个简单的示例代码,演示如何在 Java 中调用 Oracle 存储过程: ```java public class TestProcedure { Connection conn=...
下面将详细阐述如何在Java中调用存储过程,以及涉及的参数输入输出。 1. **JDBC接口调用存储过程** Java通过Java Database Connectivity (JDBC) API与数据库进行交互。要调用存储过程,首先需要建立数据库连接,...
在Java中调用存储过程的示例代码如下: ```java public static void main(String[] args) { try { Class.forName("oracle.jdbc.driver.OracleDriver"); Connection con = DriverManager.getConnection("jdbc:...
在Java中调用数据库中的存储过程是常见的操作之一,这不仅可以提高程序性能和代码可维护性,还可以更好地利用数据库的功能。根据提供的标题、描述以及部分内容,本文将详细介绍Java中调用存储过程的两种方法。 ####...
在Java中调用存储过程主要通过JDBC(Java Database Connectivity)接口实现。以下是一个基本的步骤: 1. **加载驱动**:首先,你需要加载对应数据库的JDBC驱动。例如,如果你使用的是MySQL,你可能需要`Class.for...
在Java中调用存储过程通常涉及以下步骤: 1. 加载数据库驱动:根据所使用的数据库类型(如MySQL、Oracle、SQL Server等),需要导入相应的JDBC驱动库,并使用`Class.forName()`方法加载驱动。 2. 建立连接:使用`...
本文将详细探讨如何在Java中调用存储过程,并处理返回的数组类型数据。 首先,存储过程是一种预编译的SQL语句集合,它可以包含多个SQL操作,变量、条件判断、循环等控制结构。在Oracle数据库中,可以创建一个存储...
本文将深入探讨如何在Java中调用存储过程,以及这背后涉及的相关技术点。 首先,理解存储过程的基本概念至关重要。存储过程是由数据库管理系统(如MySQL、Oracle、SQL Server等)支持的,它允许开发者编写一系列...
这是自己这段时间学习Oracle数据库的一些有关存储过程和Java中调用存储过程的学习心得。
在Java中调用存储过程主要通过`CallableStatement`接口实现,它是`PreparedStatement`的子接口,专用于调用存储过程和函数。 以下是一个基本的步骤来调用Oracle存储过程: 1. **建立数据库连接**: 使用`...