微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 准备好的语句以及连接池

我有一个关于Prepared Statement的一般用法以及连接池的问题.

准备好的语句通常仅与一个连接相关联.在我们的应用程序中,PreparedStatement在启动时创建并在稍后执行.

如果在执行某些特定的预准备语句时,与准备好的语句关联的连接正忙于执行除了如何执行此必需语句之外的其他语句.此语句将等待连接获得释放,或者此语句将优先于执行?

更新

我已经使用Apache derby数据库跟随SLEEP()函数测试了这一点,该数据库在类TimeHandlingTest中调用java函数sleep.

CREATE FUNCTION SLEEP()返回INTEGER LANGUAGE JAVA ParaMETER STYLE JAVA NO sql EXTERNAL NAME’com.derby.test.TimeHandlingTest.sleep’;

并从一个连接中创建了两个预处理语句,并从一个预处理语句中调用了Sleep()函数,并使用其他简单的sql select.Simple sql select花了几乎相同的时间(10s),其中第一个预处理语句正在休眠.这意味着一个连接对象不能用于一次执行多个准备好的声明.如果我错了,请纠正我.

解决方法:

如果您打算使用PreparedStatement,则无法将Connection返回到池.

换句话说:您只能使用从当前具有的Connection构造的PreparedStatement.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐