java中prepareStatement与createStatement的区别

首先来看两段代码:

第一个使用createStatement()

 1 public void delete( int id){
 2         try {
 3             Connection c = DBUtil.getConnection();
 4             Statement s = c.createStatement();
 5             String sql = "delete from category where id = " + id ;
 6             s.execute(sql);
 7         } catch (SQLException e) {
 8             e.printStackTrace();
 9         }
10     }

下面一段代码使用prepareStatement()完成

 1 /**
 2      * 向数据库中增加信息
 3      * @param config
 4      */
 5     public void add(Config config){
 6         String sql = "insert into category values(null,?,?)";
 7         try {
 8             Connection c = DBUtil.getConnection();
 9             PreparedStatement ps = c.prepareStatement(sql);
10             ps.setString(1, config.key);
11             ps.setString(2, config.value);
12             ps.execute();
13             ResultSet rs = ps.getGeneratedKeys();
14
15             while (rs.next()) {
16                 int id = rs.getInt(1);
17                 config.id = id;
18             }
19         } catch (SQLException e) {
20             e.printStackTrace();
21         }
22     }

可以大致看出二者的区别:

1:在概念上

prepareStatement会先初始化SQL,先把这个SQL提交到数据库中进行预处理,多次使用可提高效率。

createStatement不会初始化,没有预处理,每次都是从0开始执行SQL。

2:在变量上

prepareStatement可以在SQL中用?替换变量

String sql = "insert into category values(null,?,?)";

createStatement不支持 ? 替换变量,只能在sql中拼接参数

String sql = "delete from category where id = " + id ;

3:功能上

如果想要删除三条数据

对于createStatement,需要写三条语句

String sql = "delete from category where id = 2"  ;
String sql = "delete from category where id = 3"  ;
String sql = "delete from category where id = 7"  ;

而prepareStatement,通过set不同数据只需要生成一次执行计划,可以重用

String sql = "delete from category where id = ?"  ;

1.PreparedStatement是预编译的,对于批量处理可以大大提高效率.也叫JDBC存储过程。

2.使用createStatement 对象。在对数据库只执行一次性存取的时侯,用 createStatement对象进行处理。PreparedStatement对象的开销比createStatement大,对于一次性操作并不会带来额外的好处。

3.createStatement每次执行sql语句,相关数据库都要执行sql语句的编译,preparedstatement是预编译得,preparedstatement支持批处理

4:可重复性

对于上面的两段代码而言:第一段 id 必须给定一个值

而第二段中,对象的key,value都可以自己定义,而且大多数情况下这个语句已经被预编译过,因而当其执行时,只需DBMS运行SQL语句,而不必先编译。

这种转换也给你带来很大的便利,不必重复SQL语句的句法,而只需更改其中变量的值,便可重新执行SQL语句。

选择PreparedStatement对象与否,在于相同句法的SQL语句是否执行了多次,而且两次之间的差别仅仅是变量的不同。如果仅仅执行了一次的话,它应该和普通的对象毫无差异,体现不出它预编译的优越性。

时间: 2024-10-24 03:16:31

java中prepareStatement与createStatement的区别的相关文章

【翻译】JAVA中抽象类和接口的区别

不知道有没有人翻译过了,这篇是挺简单的,权当复习一遍内容吧. 很多常见的面试问题如"抽象类和接口有什么区别","你在什么时候用抽象类什么时候用接口".所以在这篇文章里面,我们会讨论一下这个话题. 在开始讨论它们的区别之前,我们先看看它们的介绍. Abstract class 抽象类 抽象类被用来抽象出子类的共同特征.它是不能被实例化的,它只能被子类继承作为超类使用.抽象类被用作它的子类下的层次结构创建模板(Abstract classes are used to c

java中String与StringBuilder的区别

本篇文章介绍了,java中String与StringBuilder的区别. 相信大家对 String 和 StringBuffer 的区别也已经很了解了,但是估计还是会有很多同志对这两个类的工作原理有些不清楚的地方,今天我在这里重新把这个概念给大家复习一下,顺便牵出 J2SE 5.0 里面带来的一个新的字符操作的类—— StringBuilder (先别忙着扔我砖头,我还算清醒,我这里说的不是 C #, Java 也有 StringBuilder 类).那么这个 StringBuilder 和

java中extends与implements的区别

学了java很久了,久不用之后给同学解决一个java问题的时候,就卡在这个标题上了. 下面是java中extends与implements的区别: 1. 在类的声明中,通过关键字extends来创建一个类的子类.一个类通过关键字implements声明自己使用一个或者多个接口. extends 是继承某个类, 继承之后可以使用父类的方法, 也可以重写父类的方法; implements 是实现多个接口, 接口的方法一般为空的, 必须重写才能使用 2.extends是继承父类,只要那个类不是声明为f

java中抽象类与接口的区别

转自: http://blog.csdn.net/tp7309/article/details/10452445 二者的区别快忘得差不多了,从别处看到这文章感觉写的不错,正好复习复习,也给大家分享一下. 抽象类 abstract class 包含抽象方法的类,叫抽象类.而抽象的概念就是抽象出共同属性:成员变量和方法.所以抽象类可以有private等多种权限的成员变量和非abstract的成员方法.当然抽象方法是一定要有的. 抽象类是用于单一继承的,不能实例化.而继承类一定要实现抽象方法,因为抽象

Java中Vector和ArrayList的区别

首先看这两类都实现List接口,而List接口一共有三个实现类,分别是ArrayList.Vector和LinkedList.List用于存放多个元素,能够维护元素的次序,并且允许元素的重复. 3个具体实现类的相关区别如下: ArrayList是最常用的List实现类,内部是通过数组实现的,它允许对元素进行快速随机访问.数组的缺点是每个元素之间不能有间隔,当数组大小不满足时需要增加存储能力,就要讲已经有数组的数据复制到新的存储空间中.当从ArrayList的中间位置插入或者删除元素时,需要对数组

Java中this与super的区别【6】

本文原创作者:pipi-changing 本文原创出处:http://www.cnblogs.com/pipi-changing/ 本文版权归作者和博客园共有,未经作者同意必须保留此段声明, 且在文章页面明显位置给出原文连接 ,否则保留追究法律责任的权利. Java中this与super的区别  this&super 什么是this,this是自身的一个对象,代表对象本身,可以理解为:指向对象本身的一个指针. Java关键字this只能用于方法的方法体内.当一个对象创建后, Java虚拟机(JV

java学习笔记——Java中HashMap和TreeMap的区别深入理解

本文转载自Java中HashMap和TreeMap的区别深入理解 首先介绍一下什么是Map.在数组中我们是通过数组下标来对其内容索引的,而在Map中我们通过对象来对对象进行索引,用来索引的对象叫做key,其对应的对象叫做value.这就是我们平时说的键值对. HashMap通过hashcode对其内容进行快速查找,而 TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果你就应该使用TreeMap(HashMap中元素的排列顺序是不固定的). HashMap 非线程安全 

Java中Comparable和Comparator接口区别分析

Java中Comparable和Comparator接口区别分析 来源:码农网 | 时间:2015-03-16 10:25:20 | 阅读数:8902 [导读] 本文要来详细分析一下Java中Comparable和Comparator接口的区别,两者都有比较的功能,那么究竟有什么区别呢,感兴趣的Java开发者继续看下去吧.Comparable 简介Comparable 是排序接口.若一个类实现了Comparab 本文要来详细分析一下Java中Comparable和Comparator接口的区别,

Java中&&和&以及||和|的区别

在java的逻辑运算符中,有这么四类:&&(短路与),&(与),|(或),||(短路或). &&和&都是表示与,区别是&&只要满足第一个条件,后面条件就不再判断.而&要对所有的条件都进行判断. "&"操作 代码如下: public class OperateDemo01{ /** 验证(&)"与" 操作 说明:"与" 操作 要求所有条件都判断一遍 */ pub