JDBC 的Statement&preparedStatement&CallableStatement区别

 JDBC 的Statement&preparedStatement&CallableStatement区别

JDBC statement中的preparedStatement的占位符对应着即将与之对应当值,并且一个占位符只能对应一个值,如果能对应多个就会引起混淆。sql语句是确定的,那么一个占位符必定只能对应一个值

    JDBC提供了StatementPreparedStatement CallableStatement三种方式来执行查询语句,其中 Statement 用于通用查询, PreparedStatement 用于执行参数化查询,而 CallableStatement则是用于存储过程。

    对于PreparedStatement来说,数据库可以使用已经编译过及定义好的执行计划,由于 PreparedStatement 对象已预编译过,所以其执行速度要快于 Statement 对象

     PreparedStatement预编译的。

好处:

1. 在执行可变参数的一条SQL时,PreparedStatementStatement的效率高,因为DBMS预编译一条SQL当然会比多次编译一条SQL的效率要高。   2. 安全性好,有效防止Sql注入等问题。   3.  对于多次重复执行的语句,使用PreparedStament效率会更高一点,并且在这种情况下也比较适合使用batch   4.  代码的可读性和可维护性。

posted @ 2019-06-27 16:59  枫糖浆  阅读(356)  评论(0编辑  收藏  举报