Java Statement和PreparedStatement性能测试(转)
本文转载自http://blog.csdn.net/liubo5005/article/details/7239935
先上代码:
- import java.sql.Connection;
- import java.sql.DriverManager;
- import java.sql.PreparedStatement;
- import java.sql.Statement;
- public class TestSql {
- public static void main(String[] args) throws Exception {
- testStatement();
- testBatchPreparedStatement();
- testBatchPreparedStatement();
- }
- public static void testStatement() throws Exception {
- Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();
- String url = "jdbc:db2://172.17.252.68:60012/glhssdb";
- Connection con = DriverManager.getConnection(url, "ppapdb2", "ppapdb2");
- Statement st = con.createStatement();
- Long beginTime1 = System.currentTimeMillis();
- System.out.print("insert...");
- for (int i = 0; i < 100000; i++) {
- String sql = "insert into GL_HISDB.TESTSQL(id,name) values (" + i
- + ",'" + i + "')";
- st.executeUpdate(sql);
- }
- Long endTime1 = System.currentTimeMillis();
- System.out.println("st:" + (endTime1 - beginTime1) / 1000 + "秒");// 计算时间
- st.close();
- con.close();
- }
- public static void testPreparedStatement() throws Exception {
- Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();
- String url = "jdbc:db2://172.17.252.68:60012/glhssdb";
- Connection con = DriverManager.getConnection(url, "ppapdb2", "ppapdb2");
- PreparedStatement pst = con
- .prepareStatement("insert into GL_HISDB.TESTSQL(id,name) values (?,?)");
- Long beginTime1 = System.currentTimeMillis();
- System.out.print("insert...");
- for (int i = 0; i < 100000; i++) {
- pst.setInt(1, i);
- pst.setString(2, "" + i);
- pst.execute();
- }
- Long endTime1 = System.currentTimeMillis();
- System.out.println("pst:" + (endTime1 - beginTime1) / 1000 + "秒");// 计算时间
- pst.close();
- con.close();
- }
- public static void testBatchPreparedStatement() throws Exception {
- Class.forName("com.ibm.db2.jcc.DB2Driver").newInstance();
- String url = "jdbc:db2://172.17.252.68:60012/glhssdb";
- Connection con = DriverManager.getConnection(url, "ppapdb2", "ppapdb2");
- PreparedStatement pst = con
- .prepareStatement("insert into GL_HISDB.TESTSQL(id,name) values (?,?)");
- Long beginTime1 = System.currentTimeMillis();
- con.setAutoCommit(false);// 手动提交
- System.out.print("insert...");
- for (int i = 0; i < 100000; i++) {
- pst.setInt(1, i);
- pst.setString(2, "" + i);
- pst.addBatch();
- if (i % 1000 == 0) {// 可以设置不同的大小;如50,100,500,1000等等
- pst.executeBatch();
- con.commit();
- pst.clearBatch();
- }
- }
- Long endTime1 = System.currentTimeMillis();
- System.out.println("pst batch:" + (endTime1 - beginTime1) / 1000 + "秒");// 计算时间
- pst.close();
- con.close();
- }
- }
三种调用方式Statment、PreparedStatement 以及PreparedStatement Batch,往DB2数据库插入10万条数据,跑出来的时间为:
1、insert...st:291秒 2、insert...pst:150秒 3、insert...pst batch:5秒
总结引用经典:在JDBC应用中,如果你已经是稍有水平开发者,你就应该始终以PreparedStatement代替Statement.也就是说,在任何时候都不要使用Statement。
Java Statement和PreparedStatement性能测试(转)的更多相关文章
- 【Java编程】JDBC注入攻击-Statement 与 PreparedStatement
在上一篇[Java编程]建立一个简单的JDBC连接-Drivers, Connection, Statement and PreparedStatement我们介绍了怎样使用JDBC驱动建立一个简单的 ...
- 【Java编程】建立一个简单的JDBC连接-Drivers, Connection, Statement and PreparedStatement
本blog提供了一个简单的通过JDBC驱动建立JDBC连接例程.并分别通过Statement和PreparedStatement实现对数据库的查询. 在下一篇blog中将重点比較Statement与P ...
- Java 中访问数据库的步骤?Statement 和PreparedStatement 之间的区别?
Java 中访问数据库的步骤?Statement 和PreparedStatement 之间的区别? Java 中访问数据库的步骤 1)注册驱动: 2)建立连接: 3)创建Statement: 4)执 ...
- Java的Statement、PreparedStatement、PreparedStatement + 批处理 的区别
首先来说一下连接了数据库之后执行的sql语句:通常连接了数据库之后,我们就会获得statement 类的对象或者是他的子类的对象(PreparedStatement类),通过这个对象我们就可以利用它提 ...
- Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入?
问题一:Statement和PreparedStatement的区别 先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接 ...
- 理解 Statement 和 PreparedStatement
java,servlet中的PreparedStatement 接口继承了Statement,并与之在两方面有所不同:有人主张,在JDBC应用中,如果你已经是稍有水平开发者,你就应该始终以Prepar ...
- Statement和PreparedStatement的特点 MySQL数据库分页 存取大对象 批处理 获取数据库主键值
1 Statement和PreparedStatement的特点 a)对于创建和删除表或数据库,我们可以使用executeUpdate(),该方法返回0,表示未影向表中任何记录 b)对于创建和 ...
- Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入? (转)
问题一:Statement和PreparedStatement的区别 先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接 ...
- JDBC中的Statement和PreparedStatement的差别
以Oracle为例吧 Statement为一条Sql语句生成运行计划, 假设要运行两条sql语句 select colume from table where colume=1; select col ...
随机推荐
- linq多表join与group
var query =from a in this.ObjectContext.siteInfo join b in this.ObjectContext.shopInfo on a.siteID e ...
- SQL JOINS
- ctrl+c,ctrl+d,ctrl+z在linux中意义
ctrl+c,ctrl+d,ctrl+z在linux中意义 ctrl+c和ctrl+z都是中断命令,但是他们的作用却不一样. ctrl+c是强制中断程序的执行. ctrl+z的是将任务中断 ...
- 巧用svn create patch(打补丁)方案解决定制版需求
最近项目定制版越来越多,维护,同步代码非常费事.以前的思路如下图: 以前的svn目录结构如下图: 这样问题有2个: 若在一个定制包中修复了其他定制包也有的bug,同步更新其他包的代码时,非常费劲+机械 ...
- [c#基础]AutoResetEvent
摘要 AutoResetEvent:msdn的描述是通知正在等待的线程已发生事件.此类不能被继承.也就是说它有那么一个时间点,会通知正在等待的线程可以做其它的事情了. AutoResetEvent 该 ...
- php中的正则函数主要有三个-正则匹配,正则替换
php中变量的声明? 由于php声明变量的时候, 不支持使用 var关键字, 又不能直接写一个变量名字, 孤零零的放在那里, 所以, 在php中声明变量的方式, 同时也是给变量初始化的形式, 即: & ...
- ConcurrentHashMap-----不安全线程hashmap-安全线程-hashtable
JDK1.0引入了第一个关联的集合类HashTable,它是线程安全的.HashTable的所有方法都是同步的.JDK2.0引入了HashMap,它提供了一个不同步的基类和一个同步的包装器synchr ...
- javascript自定义滚动条插件,几行代码的事儿
在实际项目中,经常由于浏览器自带的滚动条样式太戳,而且在各个浏览器中显示不一样,所以我们不得不去实现自定义的滚动条,今天我就用最少的代码实现了一个自定义滚动条,代码量区区只有几十行,使用起来也非常方便 ...
- ASP.NET中gridview获取当前行的索引值
在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作.例如,可以获得当前行某一个控件元素:设置某一元素的值等等.下面结合实例介绍几种获得GridView当前行索引值的方法. ...
- [译] ASP.NET MVC 6 attribute routing – the [controller] and [action] tokens
原文:http://www.strathweb.com/2015/01/asp-net-mvc-6-attribute-routing-controller-action-tokens/ 当在Web ...