我正在使用例如c3p0与一些定义的“maxStatements”进行prepareStatement缓存.
这个缓存真的做了什么?它缓存什么样的数据在什么级别(db,application,..)?
从示例中了解它将是很好的.例如我有一个
查询
select * from soMetable where somecolumn=?
现在我发送它没有缓存的准备好的声明.
现在我发送它,它被缓存.
有什么区别在第一种情况和第二种情况下发生了什么.在第一种情况和第二种情况下发送到DB服务器的内容?
谢谢.
没有缓存,每次从Connection中请求一个PreparedStatement时,都会得到一个新的PreparedStatement.通过缓存,如果提供相同的
sql字符串,您将经常获得类型为PreparedStatement的完全相同的
Java对象.如果您向PreparedStatement提供相同的
sql,即使使用不同的参数,通常
数据库也可以重用像执行计划那样的信息,但只有当您继续使用相同的PreparedStatement时.通过不要求您的应用程序来保持该PreparedStatement引用本身,缓存更容易.