zoukankan      html  css  js  c++  java
  • 对PreparedStatement、Statement的一点总结

    网上有很多文章讨论PrepardStatement与Statement的区别,不过要完完全全的作出比较难度很大,因为每个数据库对底层的实现及应用场合不一样,Oracle对PrepardStatement的支持最好,Mysql对PrepardStatement支持最差。Statement执行单个sql语句速度较快而PrepardStatement执行批处理的效率较高。

    以Oracle为例

     
    1、Statement为每一条Sql语句生成执行计划, 如果要执行两条sql语句
    select colume from table where colume=1;
    select colume from table where colume=2;
    会生成两个执行计划,一千个查询就生成一千个执行计划。而生成计划是非常消耗资源的

    2、PreparedStatement用于使用绑定变量重用执行计划
    select * from xxx.sometable t where t.id=?;
    通过set方法给sql语句按占位符"?"先后顺序赋值,只需要生成一个执行计划,可以重复使用。

       当处理批量SQL语句时,这个时候就可以体现PrepareStatement的优势,由于采用Cache机制,则预先编译的语句,就会放在Cache中,下次执行相同SQL语句时,则可以直接从Cache中取出来,效率要比statement高好几倍

    PrepardStatement的优点

    <1>、用PrepardStatement写成的sql语句,容易阅读,维护方便。

    <2>、批处理效率高,执行速度快。

    <3>、安全,可以防止sql注入攻击。

    缺点:当执行批处理时,你无法得知这个批处理总共影响了多少行。

  • 相关阅读:
    解决小程序sessionid不一致
    小程序实现写入缓存与读取缓存
    小程序登录时如何获取input框中的内容
    js实现截取字符串后几位
    js用正则判断身份证号码
    sublime Text3安装及配置与解决安装插件失败
    jQuery实现全选与全部选
    jQuery实现enter键登录
    常用正则表达式的判断与写法
    js实现正则判断手机号
  • 原文地址:https://www.cnblogs.com/interdrp/p/1543453.html
Copyright © 2011-2022 走看看