JDBC中createStatement加参数和不加参数效率问题

2023-12-27 11:08

本文主要是介绍JDBC中createStatement加参数和不加参数效率问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JDBC中使用createStatement加参数或不参数?

参数定义

我们都知道使用jdbc直连数据库可以执行简单的sql语句,并返回结果集ResultSet,我们在创建Statement通常默认是不加参数的,其实如果我们不加参数默认参数是这样的

createStatement()
等同于--》
createStatement(ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY)

第一个参数[ResultSet.]
【TYPE_FORWARD_ONLY 】在ResultSet中只能先前移动游标,相当于我们使用rs.next()只能往后读取,不能向前或直接取中间的某一个值
【TYPE_SCROLL_INSENSITIVE】在ResultSet中可以随心所欲的先前向后移动游标,随意取值
【TYPE_SCROLL_SENSITIVE】在ResultSet中可以随心所欲的先前向后移动游标,同时ResultSet的值有所改变的时候,可以得到改变后的最新的值
第二个参数[ResultSet.]
【CONCUR_READ_ONLY 】在ResultSet中的数据记录是只读的,可以修改
【CONCUR_UPDATABLE】在ResultSet中的数据记录可以任意修改,然后更新会数据库
详细大家可以去看看相关的文章介绍,我这边重点讨论下效率

效率问题

我这里准备了一条影响行数10万的update语句sql,分两次去执行,第一次不带参数创建Statement,第二次带参数创建

// 带参数的情况
createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE)

使用jvm自带的工具查jconsole.exe(当然jmc.exe或jvisualvm.exe都可以使用)看内存使用情况,截图如下
第一次结果:
在这里插入图片描述
第二次结果在这里插入图片描述
我都惊呆了,不带参数的堆内存和cpu占用率完全比带参的要低上好几个级别,不带参数的最高峰的堆内存占用为330Mb左右,带参数的最高峰堆内存为1.3G,这个效率上还是差很多的

当然大家使用还是要按照实际情况去选用,如果是简单的SQL执行,建议可以不带参数直接创建Statement

这篇关于JDBC中createStatement加参数和不加参数效率问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/542929

相关文章

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1