在一些系統中,對於很多對象都有相同意義上的操作,如:根據id查詢對象,商品、用戶等等實體都有這個行爲。可以將這些相同的行爲方法抽取到一個基類中,這樣就不需要在每個dao實現類中都寫一遍該方法。可以簡化衆多重複性代碼。
原理圖:
基類接口(方法抽取整合):
package com.hh.dao;
import java.io.Serializable;
import java.util.List;
import org.hibernate.criterion.DetachedCriteria;
// dao層接口抽取
public interface BaseDao<T> {
// 增加新數據
void save(T t);
// 刪除數據_根據對象
void delete(T t);
// 刪除數據_根據id
void deleteById(Serializable id);
// 修改數據_根據id
void update(T t);
// 查詢單個_根據id
T getById(Serializable id);
// 根據拼裝條件查詢類型數據總條數
Integer getTotalCount(DetachedCriteria dc);
// 根據封裝條件查詢對象集合
List<T> getPageList(DetachedCriteria dc,Integer index, Integer currentSize);
}
基類接口實現:
package com.hh.dao.impl;
import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.util.List;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Projections;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;
import com.hh.dao.BaseDao;
public class BaseDaoImpl<T> extends HibernateDaoSupport implements BaseDao<T> {
private Class claxx;
// 將過得字節碼對象的操作封裝在構造方法中
public BaseDaoImpl() {
// 獲得當前類型的帶有泛型類型的父類
ParameterizedType ptClass = (ParameterizedType) this.getClass().getGenericSuperclass();
// 獲得運行期的泛型類型
claxx = (Class) ptClass.getActualTypeArguments()[0];
}
@Override
public void save(T t) {
// 保存(添加)對象
getHibernateTemplate().save(t);
}
@Override
public void delete(T t) {
// 刪除對象
getHibernateTemplate().delete(t);
}
@Override
public void deleteById(Serializable id) {
// 使用本類方法通過id獲取對象
T t = this.getById(id);
// 刪除對象
getHibernateTemplate().delete(t);
}
@Override
public void update(T t) {
// 更新對象
getHibernateTemplate().update(t);
}
@Override
public T getById(Serializable id) {
// 根據對象類型和id查詢
return (T) getHibernateTemplate().get(claxx, id);
}
@Override
public Integer getTotalCount(DetachedCriteria dc) {
// 添加聚合條件(查詢數據行數)
dc.setProjection(Projections.rowCount());
// 進行查詢
@SuppressWarnings("unchecked")
List<Long> list = (List<Long>) getHibernateTemplate().findByCriteria(dc);
// 清空聚合
dc.setProjection(null);
// 判斷非空
if (list != null && list.size() > 0) {
return list.get(0).intValue();
} else {
return null;
}
}
@Override
public List<T> getPageList(DetachedCriteria dc, Integer index, Integer currentSize) {
// 使用HibernateTemplate提供的分頁查詢,進行查詢
List<T> list = (List<T>) getHibernateTemplate().findByCriteria(dc, index, currentSize);
return list;
}
}