但是当和Spring整合时,会有一个小问题,就是Hibernate Synchronizer产生的DAO,有自己控制Session的方法,如果直接使用Spring的HibernateTemplate,那么 Hibernate Synchronizer产生的那些DAO就变成没用处,反过来直接使用Hibernate Synchronizer产生的DAO,那么会变成自己要想办法管理session,就失去和Spring整合的方便,而如果混着用,那么session又变成不好控制。要解决这个问题就要修改Hibernate Synchronizer产生的_BaseRootDAO,让他直接extends HibernateDaoSupport
public abstract class _BaseRootDAO extends HibernateDaoSupport {...
protected Object load(Class refClass, Serializable key) {
log.debug("load " + refClass + " instance with id: " + key); try {
//使用getHibernateTemplate()去操作DB。
return getHibernateTemplate().load(refClass, key);
} catch (RuntimeException re) {
log.error("load failed", re);
throw re;
}
}
public java.util.List findBySQL(final String queryString, final String alias,
final Class refClass) {
log.debug("findBySQL queryString " + queryString);
return (List) getHibernateTemplate().execute(new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException {
SQLQuery sqlQ = session.createSQLQuery(queryString);
if (alias == null) {
sqlQ.addEntity(refClass == null ? getReferenceClass(): refClass);
} else {
sqlQ.addEntity(alias, refClass == null ? getReferenceClass() : refClass);
}
return sqlQ.list();
}
}, true);
}
protected Object load(Class refClass, Serializable key) {
log.debug("load " + refClass + " instance with id: " + key); try {
//使用getHibernateTemplate()去操作DB。
return getHibernateTemplate().load(refClass, key);
} catch (RuntimeException re) {
log.error("load failed", re);
throw re;
}
}
public java.util.List findBySQL(final String queryString, final String alias,
final Class refClass) {
log.debug("findBySQL queryString " + queryString);
return (List) getHibernateTemplate().execute(new HibernateCallback() {
public Object doInHibernate(Session session) throws HibernateException {
SQLQuery sqlQ = session.createSQLQuery(queryString);
if (alias == null) {
sqlQ.addEntity(refClass == null ? getReferenceClass(): refClass);
} else {
sqlQ.addEntity(alias, refClass == null ? getReferenceClass() : refClass);
}
return sqlQ.list();
}
}, true);
}
按照以上这个原则修改代码。就可以和spring整和在一起,在Spring架构里面使用Hibernate就变的非常简单,下面先建立业务逻辑代码
MyTestDAO" class="com.dm.dao.MyTestDAO">
sessionFactory">
mySessionFactory"/>
sessionFactory">
mySessionFactory"/>
程序代码如下:
MyTestDAO mDao = (MyTestDAO)apcontext.getBean("MyTestDAO"); //查询 用native SQL
List list = mDao.findBySQL("select XtUser.* from XT_USER XtUser ","tss"); //查询 用HQL
List list = mDao.find("from XtUser"); //新增
mDao.save(new XtUser ()); //修改
mDao.saveOrUpdate(new XtUser ()); //删除
mDao.delete(XtUser);
List list = mDao.findBySQL("select XtUser.* from XT_USER XtUser ","tss"); //查询 用HQL
List list = mDao.find("from XtUser"); //新增
mDao.save(new XtUser ()); //修改
mDao.saveOrUpdate(new XtUser ()); //删除
mDao.delete(XtUser);
修改后spring ,hibernate就能够整和在一起,以上的方法只是一个比较简单的示例,应该有个service层用来提供服务。而DAO是具体的业务实现类。这样每层之间是松散偶合。为了简便起见就没有去编写service这一层。使用HibernateSynchronizer可以提高我们的开发效率。MyEclipse的Hibernate插件不支持达梦数据库自动生成映射文件。如果每个表都需要我们去逐个来编写映像文件是比较烦琐的工作。利用HibernateSynchronize能够较好的解决这个问题。提高开发的效率。