JDBC-Ststement/PreparedStatemnent/CallableStatement
来源:互联网 发布:批量删除hbase中的数据 编辑:程序博客网 时间:2024/06/05 17:38
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>
- JDBC-Ststement/PreparedStatemnent/CallableStatement
- JDBC CallableStatement
- jdbc----CallableStatement
- JDBC基础教程之CallableStatement
- JDBC 之 CallableStatement 对象
- JDBC基础教程之CallableStatement
- JDBC基础教程之CallableStatement
- JDBC基础教程之CallableStatement
- jdbc CallableStatement 例子
- JDBC基础教程之CallableStatement
- JDBC基础教程之CallableStatement
- jdbc CallableStatement存储过程
- JDBC基础教程之CallableStatement
- JDBC: Statement、PreparedStatement和CallableStatement
- JDBC之CallableStatement 的使用
- JDBC—MeteData、PreparedStatement、CallableStatement
- JDBC - Statements, PreparedStatement and CallableStatement
- JDBC--Statement、PreparedStatement和CallableStatement
- 多线程_02_实现线程的方式
- 七月英语总结
- ZigBee网络离开机制
- 30套JSP网站源代码合集
- 观"张学锋相声考研"后所感
- JDBC-Ststement/PreparedStatemnent/CallableStatement
- 【CSDN】怎样在CSDN博客开头插入目录
- 剑指offer——矩形覆盖问题
- Lucene学习笔记之(四)特定项进行搜索
- IOS Dev Intro - UIView and CALayer
- 关于magento后台编辑器
- js 字符串转换成int或者float类型
- Bringing up interface eth0: Error: No suitable device found: no device found for connection 'System
- Android打印工具