【略有料】JDBC Statements, PreparedStatement和CallableStatement语句
当获得了与数据库的连接后,就可以与数据库进行交互了。 JDBC Statement
,CallableStatement
和PreparedStatement
接口定义了可用于发送SQL或PL/SQL命令,并从数据库接收数据的方法和属性。
它们还定义了有助于在Java和SQL数据类型的数据类型差异转换的方法。
下表提供了每个接口定义,以及使用这些接口的目的的总结。
接口 | 推荐使用 |
---|---|
Statement
|
用于对数据库进行通用访问,在运行时使用静态SQL语句时很有用。 Statement 接口不能接受参数。
|
PreparedStatement
|
当计划要多次使用SQL语句时使用。PreparedStatement 接口在运行时接受输入参数。
|
CallableStatement
|
当想要访问数据库存储过程时使用。CallableStatement 接口也可以接受运行时输入参数。
|
1. Statement对象
1.1. 创建Statement对象
在使用Statement
对象执行SQL语句之前,需要使用Connection
对象的createStatement()
方法创建一个Statement
对象,如以下示例所示:
Statement stmt = null;
try {stmt = conn.createStatement( );. . .
}
catch (SQLException e) {. . .
}
finally {. . .
}
Java
在创建Statement
对象后,可以使用它来执行一个SQL语句,它有三个执行方法可以执行。它们分别是 -
boolean execute (String SQL)
: 如果可以检索到ResultSet
对象,则返回一个布尔值true
; 否则返回false
。使用此方法执行SQLDDL
语句或需要使用真正的动态SQL,可使用于执行创建数据库,创建表的SQL语句等等。int executeUpdate (String SQL):
返回受SQL语句执行影响的行数。使用此方法执行预期会影响多行的SQL语句,例如:INSERT
,UPDATE
或DELETE
语句。ResultSet executeQuery(String SQL):
返回一个ResultSet
对象。 当您希望获得结果集时,请使用此方法,就像使用SELECT
语句一样。
1.2. 关闭Statement对象
就像关闭一个Connection
对象一样,以保存数据库资源一样,由于同样的原因,还应该关闭Statement
对象。
一个简单的调用close()
方法将执行该作业(工作)。 如果先关闭Connection
对象,它也会关闭Statement
对象。 但是,应该始终显式关闭Statement
对象,以确保正确的清理顺序。
Statement stmt = null;
try {stmt = conn.createStatement( );. . .
}
catch (SQLException e) {. . .
}
finally {stmt.close();
}
Java
为了更好的理解,建议学习Statment示例教程 。
2. PreparedStatement对象
PreparedStatement
接口扩展了Statement
接口,它添加了比Statement
对象更好一些优点的功能。
此语句可以动态地提供/接受参数。
2.1 创建PreparedStatement对象
PreparedStatement pstmt = null;
try {String SQL = "Update Employees SET age = ? WHERE id = ?";pstmt = conn.prepareStatement(SQL);. . .
}
catch (SQLException e) {. . .
}
finally {. . .
}
Java
JDBC中的所有参数都由 ?
符号作为占位符,这被称为参数标记。 在执行SQL语句之前,必须为每个参数(占位符)提供值。
setXXX()
方法将值绑定到参数,其中XXX
表示要绑定到输入参数的值的Java数据类型。 如果忘记提供绑定值,则将会抛出一个SQLException
。
每个参数标记是它其顺序位置引用。第一个标记表示位置1
,下一个位置2
等等。 该方法与Java数组索引不同(它不从0
开始)。
所有Statement
对象与数据库交互的方法(a)execute()
,(b)executeQuery()
和(c)executeUpdate()
也可以用于PreparedStatement
对象。 但是,这些方法被修改为可以使用输入参数的SQL语句。
2.2. 关闭PreparedStatement对象
就像关闭Statement
对象一样,由于同样的原因(节省数据库系统资源),也应该关闭PreparedStatement
对象。
简单的调用close()
方法将执行关闭。 如果先关闭Connection
对象,它也会关闭PreparedStatement
对象。 但是,应该始终显式关闭PreparedStatement
对象,以确保以正确顺序清理资源。
PreparedStatement pstmt = null;
try {String SQL = "Update Employees SET age = ? WHERE id = ?";pstmt = conn.prepareStatement(SQL);. . .
}
catch (SQLException e) {. . .
}
finally {pstmt.close();
}
Java
为了更好的理解,建议学习PreparedStatement示例代码 。
3. CallableStatement对象
类似Connection
对象创建Statement
和PreparedStatement
对象一样,它还可以使用同样的方式创建CallableStatement
对象,该对象将用于执行对数据库存储过程的调用。
3.1. 创建CallableStatement对象
假设需要执行以下Oracle存储过程 -
CREATE OR REPLACE PROCEDURE getEmpName (EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) AS
BEGINSELECT first INTO EMP_FIRSTFROM EmployeesWHERE 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))
BEGINSELECT first INTO EMP_FIRSTFROM EmployeesWHERE ID = EMP_ID;
END $$DELIMITER ;
SQL
存在三种类型的参数:IN
,OUT
和INOUT
。 PreparedStatement
对象只使用IN
参数。CallableStatement
对象可以使用上面三个参数类型。
以下是上面三种类型参数的定义 -
参数 | 描述 |
---|---|
IN |
创建SQL语句时其参数值是未知的。 使用setXXX() 方法将值绑定到IN 参数。
|
OUT |
由SQL语句返回的参数值。可以使用getXXX() 方法从OUT参数中检索值。
|
INOUT |
提供输入和输出值的参数。使用setXXX() 方法绑定变量并使用getXXX() 方法检索值。
|
以下代码片段显示了如何使用Connection.prepareCall()
方法根据上述存储过程来实例化一个CallableStatement
对象 -
CallableStatement cstmt = null;
try {String strSQL = "{call getEmpName (?, ?)}";cstmt = conn.prepareCall (SQL);. . .
}
catch (SQLException e) {. . .
}
finally {. . .
}
Java
String变量strSQL
表示存储过程,带有两个参数占位符。
使用CallableStatement
对象就像使用PreparedStatement
对象一样。 在执行语句之前,必须将值绑定到所有参数,否则将抛出一个SQLException
异常。
如果有IN
参数,只需遵循适用于PreparedStatement
对象的相同规则和技术; 使用与绑定的Java数据类型相对应的setXXX()
方法。
使用OUT
和INOUT
参数时,必须使用一个额外的CallableStatement
对象方法registerOutParameter()
。 registerOutParameter()
方法将JDBC数据类型绑定到存储过程并返回预期数据类型。
当调用存储过程,可以使用适当的getXXX()
方法从OUT
参数中检索该值。 此方法将检索到的SQL类型的值转换为对应的Java数据类型。
关闭CallableStatement对象
就像关闭其他Statement
对象一样,由于同样的原因(节省数据库系统资源),还应该关闭CallableStatement
对象。
简单的调用close()
方法将执行关闭CallableStatemen
t对象。 如果先关闭Connection
对象,它也会关闭CallableStatement
对象。 但是,应该始终显式关闭CallableStatement
对象,以确保按正确顺序的清理资源。
CallableStatement cstmt = null;
try {String SQL = "{call getEmpName (?, ?)}";cstmt = conn.prepareCall (SQL);. . .
}
catch (SQLException e) {. . .
}
finally {cstmt.close();
}
Java
为了更好的理解,建议参考学习Callable示例代码。
转自:JDBC Statements, PreparedStatement和CallableStatement语句 -JDBC教程
【略有料】JDBC Statements, PreparedStatement和CallableStatement语句相关推荐
- JDBC Statements, PreparedStatement
当获得了与数据库的连接后,就可以与数据库进行交互了. JDBC Statement,CallableStatement和PreparedStatement接口定义了可用于发送SQL或PL/SQL命令, ...
- On release of batch it still contained JDBC statements
最近用hiernate执行saveOrUpdate的时候,报错了.错误信息如下 2018-11-12 13:55:32,265 [WARN ] [http-bio-8080-exec-9] org.h ...
- PreparedStatement和CallableStatement都可以调用存储过程
2019独角兽企业重金招聘Python工程师标准>>> 他们都可以调用存储过程,上午收了下主要区别.但是等于放屁,说了一大推也没说个所以然,就看见了这一句,说是CallableSta ...
- JDBC:PreparedStatement 插入BLOB类型的数据,PreparedStatement 批量处理,Connection 事务处理
JDBC:PreparedStatement 插入BLOB类型的数据,PreparedStatement 批量处理,Connection 事务处理 每博一文案 村上春树说: 你要做一个不动声色的大人了 ...
- 【JDBC】PreparedStatement实现批量插入数据
题目:[JDBC]PreparedStatement实现批量插入数据 前言: PreparedStatement除了解决Statement的拼串.sql注入问题之外,还可以实现以下操作 Prepare ...
- jdbc mysql驱动_MySQL JDBC驱动程序如何处理准备好的语句
jdbc mysql驱动 准备的语句类型 在研究< 高性能Java持久性>一书中的" 语句缓存"一章时,我有机会比较了Oracle,SQL Server,Postgre ...
- Statement, PreparedStatement和CallableStatement的区别
Statement用于执行不带参数的简单SQL语句,并返回它所生成的结果,每次执行SQL豫剧时,数据库都要编译该SQL语句. Satatement stmt = conn.getStatement() ...
- JDBC中使用PreparedStatement执行SQL语句并管理结果集
基本说明 1.使用PreparedStatement在对反复操作多条结构相似的SQL语句时效率更高,并且可以使用参数替代变量,可以防止SQL注入. 2.PreparedStatement也提供了 ex ...
- jdbc 批量insert_037 深入JDBC中PreparedStatement对象使用
1. 什么是SQL注入 (1) 什么是SQL注入? 所谓SQL注入,就是通过把含有SQL语句片段的参数插入到需要执行的SQL语句中,最终达到欺骗数据库服务器执行恶意操作的SQL命令. (2) 如何解决 ...
- JDBC数据库编程:callableStatement接口
了解MySQL存储过程建立, 了解存储过程中参数传递的三种方式 了解callablestatement调用存储过程操作. 因为在现在开发中,使用存储过程的地方越来越少,所以,对于存储过程使用,只需要了 ...
最新文章
- YUM部署高版本LNMP环境
- 如何在IE/Edge浏览器中巧妙地传输HTA文件?
- Caddy-基于go的微型serve用来做反向代理和Gateway
- Linux!为何他一人就写出这么强的系统?
- HDU - 7073 Integers Have Friends 2.0 随机化 + 质因子
- 计算机英文版个人简历发文,计算机个人简历英文_英文简历.doc
- 15 张图阅尽人工智能现状
- ViewPager嵌套viewpager有什么冲突问题
- 对称与非对称密钥加密
- C语言中字符串的结束标志是什么
- Python Redis 使用
- 寒假每日一题——贝茜的报复
- 【云原生】RPC技术选型
- 人工智能在教育中的应用场景
- ACM入门及STL简介
- 服务器 uefi 安装win7系统,UEFI+GPT安装win7系统图文教程
- 手机学python语言用什么软件好_如何在手机上面学习编程?有哪些软件推荐的?...
- kaliarp欺骗注入_利用 Kali Linux 进行 Arp 欺骗,实现局域网断网攻击
- openssl 交叉编译 arm
- Comand+/不能使用
热门文章
- 背单词App开发日记4
- PyTorch中view的用法
- 跟踪状态(TASK_TRACED)
- linux服务器告警信息:Free inodes is less than xx% on /volume 排查
- 麻吉宝创世内测开启,阿里区块链邀请码AP751K
- 基于springOAuth2官方数据库表结构的简单权限控制
- AOSP、AOKP、CM的区别
- 沈阳市中考计算机考试时间,2021辽宁沈阳中考考试时间、科目分值及时间轴
- 阵列服务器怎么拆硬盘盒,磁盘阵列硬盘盒拆解和安装,很详细
- android 涨潮动画加载_这是迪士尼动画片《长发公主》中王国的原型,涨潮时才浮出海面...