JDBC-Ststement/PreparedStatemnent/CallableStatement
2016-07-30 10:48
561 查看
Statement | 使用通用访问数据库。当在运行时使用静态SQL语句。 Statement接口不能接受的参数。 |
PreparedStatement | 当计划多次使用SQL语句。 那么可以PreparedStatement接口接收在运行时输入参数。 |
CallableStatement | 当要访问数据库中的存储过程中使用。 CallableStatement对象的接口还可以接受运行时输入参数。 |
使用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) AS BEGIN 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()方法检索值。 |
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>
相关文章推荐
- 偷笑偷笑偷笑这就是有病的表现
- CR95HF操作命令介绍
- G - Fire![bfs]
- popwindows
- Catch That Cow
- HDU-2012-素数判定【打表】
- achartengine图标框架的使用心得
- 将博客搬至CSDN
- 论 <%@taglib prefix="s" uri="/struts-tags" %> 的重要性
- jquery 遍历表格,需要表格中每个td的内容
- 细菌(disease) (位运算)(状态压缩)
- jsp-九大内置对象
- 协方差矩阵
- jsp-简单小程序(乘法表、)
- 数据结构-归并排序
- 排序算法的时间复杂度和空间复杂度
- 数据结构-快速排序算法
- 数据结构-二分查找
- 斐波那契额序列
- 数据结构-冒泡排序算法