这几天在做物流的项目,自己搭建环境时,Dao层代码需要抽取公共的。
我在下面写了一个 setSuperSessionFactory的方法,主要是因为继承了HibernateDaoSupport,而父类的setSessionFactory又是final的,所以就另外写了一个 setSuperSessionFactory的方法,然后通过Spring注解注入;如果不采用这种方式那么需要在XML文件中配置<Property name="sessionFactory" ref="sessionFactory">,这样来的话,需要在每一个继承Dao的类中都要写,那就显得太繁琐了。
然后下面写了一个public Class<T> getClz()的方法,主要是获取泛型中的Class对象,从而来轻松的得到我们所需要的;以前我没有用到这个方法的时候,是通过构造函数的方式将类名传过来的(在xml中配置<constructor-arg index="0" type="java.lang.String" value="com.jasun.bos.domain.User"></constructor-arg>),从而我们可以看到这种方式也太繁琐。
package com.jasun.bos.dao;
import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.util.List;
import javax.annotation.Resource;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.DetachedCriteria;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
/**
* 使用DAO 的通用功能
* @author Jasun
*
*/
@SuppressWarnings("all")
public class GenericDAO<T> extends HibernateDaoSupport {
@Resource(name="sessionFactory")
public void setSuperSessionFactory(SessionFactory sessionFactory){
super.setSessionFactory(sessionFactory);
}
/**
* 创建一个Class的对象来获取泛型的class
*/
private Class<T> clz;
/**
* 获得泛型的Class类
* @return
*/
public Class<T> getClz() {
if (clz == null) {
// 获取泛型的Class对象
clz = ((Class<T>) (((ParameterizedType) (this.getClass()
.getGenericSuperclass())).getActualTypeArguments()[0]));
}
return clz;
}
// 通用保存方法
public void save(T obj) {
this.getHibernateTemplate().save(obj);
}
// 通用修改方法
public void update(T obj) {
this.getHibernateTemplate().update(obj);
}
// 通用删除方法
public void delete(T obj) {
this.getHibernateTemplate().delete(obj);
}
// 通用查询方法
public List<T> findAll() {
return this.getHibernateTemplate().find("from " + this.getClz().getName());
}
// 根据id 查询
public T findById(Serializable id) {
Class c = null;
try {
c = Class.forName(this.getClz().getName());
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return (T) this.getHibernateTemplate().get(c, id);
}
// 根据条件 查询
public List<T> findByNamedQuery(String queryName, Object... args) {
return this.getHibernateTemplate().findByNamedQuery(queryName, args);
}
public List<T> findByDetachedCriteria(DetachedCriteria detachedCriteria) {
return this.getHibernateTemplate().findByCriteria(detachedCriteria);
}
}