java – PreparedStatement缓存 – 它是什么意思(它是如何工作的)

我正在使用例如c3p0与一些定义的“maxStatements”进行prepareStatement缓存.
这个缓存真的做了什么?它缓存什么样的数据在什么级别(db,application,..)?
从示例中了解它将是很好的.例如我有一个查询

select * from soMetable where somecolumn=?

现在我发送它没有缓存的准备好的声明.
现在我发送它,它被缓存.
有什么区别在第一种情况和第二种情况下发生了什么.在第一种情况和第二种情况下发送到DB服务器的内容

谢谢.

解决方法

没有缓存,每次从Connection中请求一个PreparedStatement时,都会得到一个新的PreparedStatement.通过缓存,如果提供相同的sql字符串,您将经常获得类型为PreparedStatement的完全相同的 Java对象.如果您向PreparedStatement提供相同的sql,即使使用不同的参数,通常数据库也可以重用像执行计划那样的信息,但只有当您继续使用相同的PreparedStatement时.通过不要求您的应用程序来保持该PreparedStatement引用本身,缓存更容易.

相关文章

应用场景 C端用户提交工单、工单创建完成之后、会发布一条工...
线程类,设置有一个公共资源 package cn.org.chris.concurre...
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量