利用jdbc操作数据库——prepareStatement和Statement的比较以及利用batch模式提高效率的心得

本文对比了Statement与PreparedStatement的性能,详细解析了预编译SQL、批处理、事务手动提交及rewriteBatchedStatements参数对数据库操作效率的影响,尤其强调了在批量插入场景下,使用PreparedStatement结合批处理和rewriteBatchedStatements=true的最优实践。
摘要由CSDN通过智能技术生成

1.prepareStatement   vs  statement

(1)prepareStatement预编译SQL语句,批处理效率高

什么是预编译,好处?(参考https://blog.csdn.net/Marvel__Dead/article/details/69486947
当客户发送一条SQL语句给服务器后,服务器总是需要校验SQL语句的语法格式是否正确,然后把SQL语句编译成可执行的函数,最后才是执行SQL语句。其中校验语法,和编译所花的时间可能比执行SQL语句花的时间还要多。
注意:可执行函数存储在MySQL服务器中,并且当前连接断开后,MySQL服务器会清除已经存储的可执行函数。
如果我们需要执行多次insert语句,但只是每次插入的值不同,MySQL服务器也是需要每次都去校验SQL语句的语法格式,以及编译,这就浪费了太多的时间。如果使用预编译功能,那么只对SQL语句进行一次语法校验和编译,所以效率要高。

看个例子:
statement:

stmt = conn.createStatement();
//循环
for(){
    stmt.executeUpdate(sql);
}

prepareStatement:

ps = conn.prepareStatement(sql);
//循环
for(){
    ps.setString(1,"");
    ps.set

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值