我想知道当我在hibernate中使用c3p0连接池时是否应该使用session.close()
?或c3p0在一定的时间间隔后自动关闭?我是否需要通过打开会话会话?
SessionFactory factory = HibernateUtil.getSessionFactory();
Session session=factory.openSession();
因为在下面的教程中它不会关闭会话。
什么是正确的方法是什么?
编辑:
这将是我的代码
@SuppressWarnings("unchecked")
@Override
public JSONObject getUserDetails(int id) {
long lStartTime = new Date().getTime();
JSONObject obj = new JSONObject();
try(Session session=factory.openSession()) {
Employee emp=(Employee)session.load(Employee.class,id);
if(emp != null) {
obj.put("id", emp.getId());
obj.put("name", emp.getName());
}
long lEndTime = new Date().getTime();
log.info("[ Personal Details ]Time elapsed For Fetching :"+(lEndTime - lStartTime));
} catch (Exception e) {
// TODO: handle exception
}
}
谢谢艾略特。但是,我的问题是我应该在代码中明确写入“session.close()”吗? – Syed
如果你不使用'try-with-resources',那么**是**你应该明确地*在'finally''块中写'session,close()'。 –
感谢您的更新。但究竟是什么使差异? – Syed