JDBC-Ststement/PreparedStatemnent/CallableStatement

来源:互联网 发布:批量删除hbase中的数据 编辑:程序博客网 时间:2024/06/05 17:38

Statement使用通用访问数据库。当在运行时使用静态SQL语句。 Statement接口不能接受的参数。PreparedStatement当计划多次使用SQL语句。 那么可以PreparedStatement接口接收在运行时输入参数。CallableStatement当要访问数据库中的存储过程中使用。 CallableStatement对象的接口还可以接受运行时输入参数。

Statement对象

使用Statement对象执行SQL语句,需要使用Connection对象的createStatement( )方法创建:

Statement stmt = null;try {   stmt = conn.createStatement( );   . . .}catch (SQLException e) {   . . .}finally {   . . .}

一旦创建了一个Statement对象,然后可以用它来与它的三个执行方法之一执行SQL语句。

  • boolean execute(String SQL) : 如果ResultSet对象可以被检索返回布尔值true,否则返回false。使用这个方法来执行SQL DDL语句,或当需要使用真正的动态SQL。

  • int executeUpdate(String SQL) : 返回受影响的SQL语句执行的行的数目。使用此方法来执行,而希望得到一些受影响的行的SQL语句 - 例如,INSERT,UPDATE或DELETE语句。

  • ResultSet executeQuery(String SQL) : 返回ResultSet对象。当希望得到一个结果集使用此方法,就像使用一个SELECT语句。

关闭 Statement 对象:

关闭一个Connection对象来保存数据库资源,也应该关闭Statement对象。

close()方法简单的调用将完成这项工作。如果关闭了Connection对象首先它会关闭Statement对象。应该始终明确关闭Statement对象,以确保正确的清除。

Statement stmt = null;try {   stmt = conn.createStatement( );   . . .}catch (SQLException e) {   . . .}finally {   stmt.close();}

PrepareStatement

PreparedStatement接口扩展了Statement接口,让过一个通用的Statement对象增加了几个高级功能。

statement 提供动态参数的灵活性。

创建PreparedStatement 对象:

PreparedStatement pstmt = null;try {   String SQL = "Update box SET age = ? WHERE id = ?";   pstmt = conn.prepareStatement(SQL);   . . .}catch (SQLException e) {   . . .}finally {   . . .}<span class="pun" style="color:#66660;margin: 0px; padding: 0px;"></span>

在JDBC中所有的参数都被?符号代表,这是已知的参数标记。在执行SQL语句之前,必须提供每一个参数。

setXXX()方法将值绑定到参数,其中XXX表示希望绑定到输入参数值的Java数据类型。如果忘了提供值,将收到一个SQLException。

每个参数标记是由它的序号位置引用。第一标记表示位置1,下一个位置为2 等等。这种方法不同于Java数组索引,以0开始,而是从1开始的

所有的Statement的方法a) execute(), (b) executeQuery(), 及(c) executeUpdate() 也与PreparedStatement对象工作。然而,该方法被修改为使用SQL语句,可以使用输入的参数。

关闭PreparedStatement对象:

正如关闭Statement对象,出于同样的原因,也应该关闭PreparedStatement的对象。

close()方法简单的调用将完成这项工作。如果关闭了Connection对象首先它会关闭PreparedStatement对象。然而,应该始终明确关闭PreparedStatement对象,以确保正确的清除。

PreparedStatement pstmt = null;try {   String SQL = "Update box SET age = ? WHERE id = ?";   pstmt = conn.prepareStatement(SQL);   . . .}catch (SQLException e) {   . . .}finally {   pstmt.close();}<span class="pun" style="color:#66660;margin: 0px; padding: 0px;"></span>


CallableStatement 对象:

创建CallableStatement 对象:

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

CREATE OR REPLACE PROCEDURE getEmpName    (EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) ASBEGIN   SELECT first INTO EMP_FIRST   FROM Employees   WHERE ID = EMP_ID;END;<span class="pun" style="color:#66660;margin: 0px; padding: 0px;"></span>

注:上面的存储过程已写入Oracle,但我们正在使用MySQL数据库,为了对MySQL写相同的存储过程,在数据库中创建它:

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 ;<span class="pun" style="color:#66660;margin: 0px; padding: 0px;"></span>

三种类型的参数有:IN,OUT和INOUT。 PreparedStatement对象只使用IN参数。 CallableStatement对象可以使用所有三个。

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

下面的代码片段显示了如何使用该Connection.prepareCall()方法实例化基于上述存储过程CallableStatement对象:

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

String变量的SQL表示存储过程,使用参数占位符。

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

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

当使用OUT和INOUT参数就必须采用额外的CallableStatement及registerOutParameter()方法。registerOutParameter()方法JDBC数据类型绑定到数据类型的存储过程应返回。

一旦调用存储过程,用适当的getXXX()方法输出参数检索值。这种方法投射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();}<span class="pun" style="color:#66660;margin: 0px; padding: 0px;"></span>





0 0
原创粉丝点击