JDBC存储过程调用

在讨论JDBC Statement教程文章时,我们已经学习了如何在JDBC中使用存储过程。 本教程文章与该部分类似,但它将讲解演示有关JDBC SQL转义语法的其他信息。

就像Connection对象创建StatementPreparedStatement对象一样,它可使用同样的方式创建CallableStatement对象,该对象将用于执行对数据库存储过程的调用。

创建CallableStatement对象

假设需要执行以下Oracle存储过程 -

CREATE OR REPLACE PROCEDURE getEmpName
   (EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) AS
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END;

SQL

注意:上面的存储过程是为Oracle编写的,但是如果使用MySQL数据库,参考以下代码为MySQL编写相同的存储过程,如下在EMP数据库中创建它 -

DELIMITER $$

DROP PROCEDURE IF EXISTS `EMP`.`getEmpName` $$
CREATE PROCEDURE `EMP`.`getEmpName`
   (IN EMP_ID INT, OUT EMP_FIRST VARCHAR(255))
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END $$

DELIMITER ;

SQL

存在三种类型的参数:INOUTINOUT。 PreparedStatement对象只使用IN参数。 CallableStatement对象可以使用上面三种类型参数。

以下是上面三种类型参数的定义 -

参数 描述
IN 创建SQL语句时其参数值是未知的。 使用setXXX()方法将值绑定到IN参数。
OUT 由SQL语句返回的参数值。可以使用getXXX()方法从OUT参数中检索值。
INOUT 提供输入和输出值的参数。使用setXXX()方法绑定变量并使用getXXX()方法检索值。

以下代码片段显示了如何使用Connection.prepareCall()方法根据上述存储过程来实例化一个CallableStatement对象 -

CallableStatement cstmt = null;
try {
   String str = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   . . .
}

Java

String变量str表示存储过程,带有参数占位符。

使用CallableStatement对象与使用PreparedStatement对象很像。 在执行语句之前,必须将值绑定到所有参数,否则将收到一个SQLException异常。

如果有IN参数,只需遵循适用于PreparedStatement对象的相同规则和技术; 使用与绑定的Java数据类型相对应的setXXX()方法。

使用OUTINOUT参数时,必须使用一个额外的CallableStatement对象方法registerOutParameter()。 registerOutParameter()方法将JDBC数据类型绑定到存储过程预期返回的数据类型。

当调用存储过程后,可以使用适当的getXXX()方法从OUT参数中检索该值。 此方法将检索到的SQL类型的值转换为Java数据类型。

关闭CallableStatement对象

就像关闭其他Statement对象一样,由于同样的原因(节省资源),还应该关闭CallableStatement对象。

简单的调用close()方法将执行关闭工作。 如果先关闭Connection对象,它也会关闭CallableStatement对象。 但是,应该始终显式关闭CallableStatement对象,以确保正确的顺序清理。

CallableStatement cstmt = null;
try {
   String SQL = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   cstmt.close();
}

Java

有关更多的细节,建议学习研究“Callable实例代码”

JDBC SQL转义语法

通过使用标准JDBC方法和属性,转义语法使您能够灵活地使用不可用的数据库特定功能。

一般SQL转义语法格式如下 -

{keyword ‘parameters‘}

以下是以下转义序列,在执行JDBC编程时非常有用 -

d, t, ts关键字

它们用于帮助确定日期,时间和时间戳文字。没有哪两个DBMS表示时间和日期的方式相同。 该转义语法告诉驱动程序以目标数据库的格式呈现日期或时间。 例如 -

{d ‘yyyy-mm-dd‘}

yyyy=年份,mm=月份; dd=日期。 使用这种语法{d‘2019-09-03‘}表示的是2019年3月9日。

这是一个简单的示例,显示如何将日期插入表中 -

//Create a Statement object
stmt = conn.createStatement();
//Insert data ==> ID, First Name, Last Name, DOB
String sql="INSERT INTO STUDENTS VALUES" +
             "(100,‘Kobe‘,‘Bryant‘, {d ‘2002-12-16‘})";

stmt.executeUpdate(sql);

Java

同样,还可以使用以下两种语法:tts -

{t ‘hh:mm:ss‘}

这里,hh=小时,mm =分钟, ss =秒。 使用这种语法{t ‘13:30:29‘}1:30:29 PM

{ts ‘yyyy-mm-dd hh:mm:ss‘}

这里“d”和“t”是上述两种语法的组合语法来表示时间戳。

escape关键字

escape关键字标识LIKE子句中使用转义字符。 使用SQL通配符%(与0个或多个字符匹配)时很有用。 例如 -

String sql = "SELECT symbol FROM MathSymbols
              WHERE symbol LIKE ‘\%‘ {escape ‘\‘}";
stmt.execute(sql);

Java

如果使用反斜杠字符(\)作为转义字符,则还必须在Java字符串文字中使用两个反斜杠字符,因为反斜杠也是Java转义字符。

fn 关键字

这个关键字表示DBMS中使用的标量函数。 例如,可以使用SQL函数长度来获取字符串的长度 -

{fn length(‘Hello World‘)}

Java

上面语句返回结果值为:11,也就是字符串’Hello World‘的长度。

call 关键字

此关键字用于调用存储过程。 例如,对于需要IN参数的存储过程,请使用以下语法 -

{call my_procedure(?)};

Java

对于需要IN参数并返回OUT参数的存储过程,请使用以下语法 -

{? = call my_procedure(?)};

Java

oj关键字

此关键字用于表示外部连接。 语法如下 -

{oj outer-join}

Java

这里,outer-join = table {LEFT|RIGHT|FULL} OUTERJOIN {table | outer-join} 搜索条件。 例如 -

String sql = "SELECT Employees
              FROM {oj ThisTable RIGHT
              OUTER JOIN ThatTable on id = ‘100‘}";
stmt.execute(sql);

原文地址:https://www.cnblogs.com/borter/p/9608798.html

时间: 2024-11-08 21:25:14

JDBC存储过程调用的相关文章

SQLSERVER JDBC 存储过程调用偶尔很慢的原因之一【sp_sproc_columns】

在对于CallableStatement进行参数赋值或者取值时,建议直接用索引号,避免使用参数名称! 若使用参数名称,每次调用该存储过程时,jdbc会自动执行 exec sp_sproc_columns的存储过程,获取指定存储过程的对应参数. 不知道具体原因,但是在本机时候,调用该存储过程的表现非常不稳定,从几毫秒到十几秒都有出现过.若有知道原因的童鞋,烦请告知一声!

jdbc中的Statement对象和Preparedstatement对象的区别,以及通过jdbc操作调用存储过程

一. java.sql.*   和  javax.sql.*的包的类结构 |- Driver接口: 表示java驱动程序接口.所有的具体的数据库厂商要来实现此接口. |- connect(url, properties):  连接数据库的方法. url: 连接数据库的URL URL语法: jdbc协议:数据库子协议://主机:端口/数据库 user: 数据库的用户名 password: 数据库用户密码 |- DriverManager类: 驱动管理器类,用于管理所有注册的驱动程序 |-regis

JDBC存储过程的调用

一. JDBC存储过程的调用 (1)存储过程是用SQL语句和控制流语句等编写的一段程序代码,在创建时已被编译成机器代码并存储在数据库中供客户端调用. 存储过程有以下优点: 1.所生成的机器代码被永久存储在数据库中,客户端调用时不需要重新编译,执行起来效率要高一些. 2.存储过程的网络使用效率比等效的SQL 语句要高. (2)JDBC通过java.sql.CallableStatement接口调用数据库服务器中的存储过程: (3)CallableStatement接口继承了PreparedStat

toad调用存储过程,存储过程调用sql 类

1.定义一个sql 类Hello DROP JAVA SOURCE NEWXZXT."Hello"; CREATE OR REPLACE AND RESOLVE JAVA SOURCE NAMED NEWXZXT."Hello" as import java.lang.*; public class Hello { public static String say(String args) { System.out.println(args); return arg

Oracle 存储过程调用返回游标的另一个存储过程。

一个扩展存储过程调用另一个存储过程,示例: 被调用存储过程:最后会返回一个游标,游标返回一个值.调用这个存储过程的存储过程同样需要获取它. procedure SearchBill --根据到货单号查询所有行号 ( P_code VARCHAR, P_UserCode varchar , P_org varchar, P_warehouse varchar, p_movetype varchar, p_billtype varchar, p_note varchar, p_isred varch

在ado.net中实现oracle存储过程调用两种方式

  1.常规的存储过程调用 String or=ConfigurationManager.ConnectionStrings["conn"].ToString(); OracleConnection oc = new OracleConnection(or); oc.Open(); OracleCommand om = oc.CreateCommand(); om.CommandType = CommandType.StoredProcedure; om.CommandText = &

c#中两种不同的存储过程调用与比较

存储过程简介 简单的说,存储过程是由一些SQL语句和控制语句组成的被封装起来的过程,它驻留在数据库中,可以被客户应用程序调用,也可以从另一个过程或触发器调用.它的参数可以被传递和返回.与应用程序中的函数过程类似,存储过程可以通过名字来调用,而且它们同样有输入参数和输出参数. 根据返回值类型的不同,我们可以将存储过程分为三类:返回记录集的存储过程, 返回数值的存储过程(也可以称为标量存储过程),以及行为存储过程.顾名思义,返回记录集的存储过程的执行结果是一个记录集,典型的例子是从数据库中检索出符合

ThinkPHP3.1在多数据库连接下存储过程调用bug修正

最近使用ThinkPHP3.1进行一个项目的开发,由于该项目需要连接多台不同的数据库,所以使用如下配置方法: 1 <?php 2 return array( 3 //'配置项'=>'配置值' 4 //数据库配置 5 'DB_PREFIX' => '', 6 'DB_BLACK_FP' => array( 7 'db_type' => 'mysql', 8 'db_user' => 'xxx', 9 'db_pwd' => 'xxx', 10 'db_host' =

ORACLE存储过程调用Web Service

1. 概述 最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明.其他主流数据库,比如mysql和sql service,调用web service的方法这里就不做介绍了,本文主要用来介绍oracle存储过程调用Web Service的方法. 众所周知,在Web Service通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明