這幾天在做物流的項目,自己搭建環境時,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);
}
}