java 多次执行一个sql后 释放不了数据库连接池 怎么办 代码如下!求解决

Stringsql="selectidfrom"+GO_SERVER[i]+"whereautoId>"+SERVER_FULL_VALUE;Sessions=this.... String sql = "select id from " + GO_SERVER[i] + " where autoId>"
+ SERVER_FULL_VALUE;
Session s = this.getSession();
Query q = s.createSQLQuery(sql);//多次执行后 该句报错
if (q.list().size() == 0) {
index = i + 1;
break;
}
s.close();
展开
 我来答
天天好宝宝
推荐于2018-04-04 · TA获得超过373个赞
知道小有建树答主
回答量:603
采纳率:0%
帮助的人:492万
展开全部
貌似你的if段里面有个break吧!不知道你这段语句是否是在某循环中吧
如果碰到break就会退出循环,就别说后面的s.close()了
也就是说数据连接无法合理关闭,可能会出现各种溢出,连接不够用等
喵惠
2013-01-26 · TA获得超过333个赞
知道小有建树答主
回答量:169
采纳率:76%
帮助的人:81.7万
展开全部
getSession() 返回的 session 是会话级别的, 也就是工作单元级别。 通俗点讲, 也就是默认只能执行一条 SQL 语句。
如果你想重复利用一个 Session 执行多条 SQL 语句, 那么, 请使用 getCurrentSession() 线程级别的 Session。
你试试看, 希望对你有帮助。 GOOD LUCK FOR U ^_^
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式