`

JDBC 调用 存储过程

 
阅读更多

一、无返回值的存储过程

 

PROC :

create or replace procedure insert_user(

        username in varchar2,

        userpassword in varchar2 )

as

begin  

insert into userInfo values(wepull_books.nextval,username,userpassword);

end insert_user;

 

 

在java里调用时就用下面的代码:

 CallableStatement cst = con.prepareCall("{call insert_user(?,?) }");   

 

//设置两个问号的值   

cst.setString(1, "zhangxuan");   

cst.setString(2, "123");   

 

//执行SQL语句   

cst.execute();   

con.close();

 

 

二:有返回值的存储过程(非列表)

 

存储过程

create or replace procedure check_user(

        username in varchar2,

        userpassword in varchar2,

        userCount out integer )

as

begin

   select  count(*) into userCount from userInfo where uname=username and password=userpassword;

end check_user;

 

 

java代码

// 设置要执行的SQL语句,如果是执行存储过程,那么执行存储过程的格式按括号内所示   

CallableStatement cst = con.prepareCall("{call check_user(?,?,?) }");

// 设置存储过程中两个输入参数的值   

cst.setString(1, "zhangxuan");   

cst.setString(2, "123");   

// 设置存储过程中输出参数的值   

cst.registerOutParameter(3, Types.INTEGER);   

// 执行SQL语句   

cst.execute();   

// 执行完存储过程后,取得存储过程中输出参数的值   

int testPrint = cst.getInt(3);   

System.out.println(testPrint);

 

 

注意 :

这里的cst.getInt(3) ;并不是随意写的3而是这里的out参数在第三个位置,如果在第二个位置,则cst.getInt(2);依次类推。

 

 

三:返回列表 

由于oracle存储过程没有返回值,它的所有返回值都是通过out参数来替代的,列表同样也不例外,但由于是集合,所以不能用一般的参数,必须要用pagkage了.所以要分两部分。

1, 建一个程序包。如下:

CREATE OR REPLACE PACKAGE TESTPACKAGE 

AS 

TYPE Test_CURSOR IS REF CURSOR;

end TESTPACKAGE;

2,建立存储过程,存储过程为:

CREATE OR REPLACE PROCEDURE TESTC(p_CURSOR out TESTPACKAGE.Test_CURSOR)

 IS

BEGIN 

    OPEN p_CURSOR FOR SELECT * FROM HYQ.TESTTB;

END TESTC;

可以看到,它是把游标(可以理解为一个指针),作为一个out 参数来返回值的。

 

java代码 :

CallableStatement proc = null;      

proc = conn.prepareCall("{ call hyq.testc(?) }");      

proc.registerOutParameter(1,oracle.jdbc.OracleTypes.CURSOR);      

proc.execute();      

rs = (ResultSet)proc.getObject(1)

 while(rs.next())      

{

           System.out.println("<tr><td>" + rs.getString(1) + "</td><td>"+rs.getString(2)+"</td></tr>"); 

}      

分享到:
评论

相关推荐

    JDBC 调用存储过程方法

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

    JDBC调用存储过程

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

    jdbc调用存储过程

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

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

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

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

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

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

    jdbc调用存储过程?.avi

    jdbc调用存储过程 函数例子

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

    JDBC调用存储过程的小例子

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

    JDBC调用存储过程.pdf

    ### JDBC调用存储过程知识点详解 #### 一、引言 在Java开发中,通过Java Database Connectivity (JDBC) 来访问数据库是非常常见的操作。其中,调用存储过程是实现复杂业务逻辑的一种重要方式。存储过程是预编译好...

    jdbc执行存储过程

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

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

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

    Java面试题31.jdbc调用存储过程.mp4

    Java面试题31.jdbc调用存储过程.mp4

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

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

    android通过jdbc方式连接mysql,并执行存储过程

    android通过jdbc方式连接mysql,并执行存储过程。连接数据库部分最好新建一个线程来实现和主线程分开。编译之前确定添加了mysql-connector-java-5.0.8-bin库否则会出错

    jdbc针对存储过程通用的jdbc封装.zip

    JDBC调用存储过程的基本步骤如下: 1. 加载数据库驱动并建立连接:使用`Class.forName()`加载驱动,然后通过`DriverManager.getConnection()`建立与数据库的连接。 2. 创建CallableStatement对象:与...

    JDBC存储过程的调用

    JDBC存储过程的调用

    JDBC调用过程与函数源码

    调用存储过程使用`CallableStatement`,它的执行方式与PreparedStatement类似。注意,过程的调用通常以`{call}`开头,后面跟着过程名和括号内的参数。 ```java CallableStatement cs = conn.prepareCall("{call ...

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

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

Global site tag (gtag.js) - Google Analytics