日期:2014-05-17  浏览次数:20718 次

请教hibernate问题
public int getCount1(Company company,Object param)
{
int count = 0;
if (company != null) {
Session session = (Session) em.getDelegate();
Criteria criteria = session.createCriteria(Company.class);
if (company.getCompanyname() != null && company.getCompanyname().trim().length() > 0)
criteria.add(Restrictions.like("companyname", company.getCompanyname(),
MatchMode.ANYWHERE));

count = ((Number) criteria.setProjection(Projections.rowCount())
.uniqueResult()).intValue();
}
return count;
}
割---------
Session session = (Session) em.getDelegate();
这里用EntityManager.getDelegate得到session.
当得到结果count后,要不要手动将session关闭?
service层中,用了spring的@Transactional注解



------解决方案--------------------
这个要!你要调用spring框架下的hibernateTemple,spring才能管理session
------解决方案--------------------
自己获取session来操作,session是要自己关闭的;
不过如果你非要获取session也可以这么做:
getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException {
这个session可以被spring关闭
 
}
------解决方案--------------------
自己获取session来操作,session是要自己关闭的