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

前端之家收集整理的这篇文章主要介绍了java – PreparedStatement缓存 – 它是什么意思(它是如何工作的)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用例如c3p0与一些定义的“maxStatements”进行prepareStatement缓存.
这个缓存真的做了什么?它缓存什么样的数据在什么级别(db,application,..)?
从示例中了解它将是很好的.例如我有一个查询

select * from soMetable where somecolumn=?

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

谢谢.

解决方法

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

猜你在找的Java相关文章