dao實現模板
package cn.jxlg.oa.util;
import java.lang.reflect.ParameterizedType;
import java.util.Collections;
import java.util.List;
import javax.annotation.Resource;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.transaction.annotation.Transactional;
import cn.jxlg.oa.domain.PageBean;
//@Transactional註解可以被繼承
//@Transactional註解對父類中聲明的方法無效
@Transactional
@SuppressWarnings("unchecked")
public class DaoSupportImpl<T> implements DaoSupport<T> {
@Resource
private SessionFactory sessionFactory;
private Class<T> clazz;
public DaoSupportImpl() {
// 使用反射技術得到T的真實類型
ParameterizedType pt = (ParameterizedType) this.getClass().getGenericSuperclass(); // 獲取當前new的對象的 泛型的父類 類型
this.clazz = (Class<T>) pt.getActualTypeArguments()[0]; // 獲取第一個類型參數的真實類型
}
/**
* 獲取當前可用的Session
*
* @return
*/
public Session getSession(){
return sessionFactory.getCurrentSession();
}
@Override
public void save(T t) {
getSession().save(t);
}
@Override
public void update(T t) {
getSession().update(t);
}
@Override
public void delete(Long id) {
Object obj = findById(id);
if (obj != null) {
getSession().delete(obj);
}
}
@Override
public T findById(Long id) {
if(id==null){
return null;
}else{
return (T) getSession().get(clazz, id);
}
}
@Override
public List<T> findByIds(Long[] ids) {
if(ids==null||ids.length==0){
return Collections.EMPTY_LIST;
}else{
return getSession().createQuery(//
"FROM "+clazz.getSimpleName()+" WHERE id IN (:ids)")//
.setParameterList("ids", ids)//
.list();
}
}
@Override
public List<T> findAll() {
return getSession().createQuery(//
"FROM " + clazz.getSimpleName())//
.list();
}
// 公共的查詢分頁信息的方法
@Deprecated
public PageBean getPageBean(int pageNum, int pageSize, String hql, List<Object> parameters) {
System.out.println("-------> DaoSupportImpl.getPageBean()");
// 查詢本頁的數據列表
Query listQuery = getSession().createQuery(hql); // 創建查詢對象
if (parameters != null) { // 設置參數
for (int i = 0; i < parameters.size(); i++) {
listQuery.setParameter(i, parameters.get(i));
}
}
listQuery.setFirstResult((pageNum - 1) * pageSize);
listQuery.setMaxResults(pageSize);
List list = listQuery.list(); // 執行查詢
// 查詢總記錄數量
Query countQuery = getSession().createQuery("SELECT COUNT(*) " + hql);
if (parameters != null) { // 設置參數
for (int i = 0; i < parameters.size(); i++) {
countQuery.setParameter(i, parameters.get(i));
}
}
Long count = (Long) countQuery.uniqueResult(); // 執行查詢
return new PageBean(pageNum, pageSize, count.intValue(), list);
}
// 公共的查詢分頁信息的方法(最終版)
public PageBean getPageBean(int pageNum, int pageSize, QueryHelper queryHelper) {
System.out.println("-------> DaoSupportImpl.getPageBean( int pageNum, int pageSize, QueryHelper queryHelper )");
// 參數列表
List<Object> parameters = queryHelper.getParameters();
// 查詢本頁的數據列表
Query listQuery = getSession().createQuery(queryHelper.getListQueryHql()); // 創建查詢對象
if (parameters != null) { // 設置參數
for (int i = 0; i < parameters.size(); i++) {
listQuery.setParameter(i, parameters.get(i));
}
}
listQuery.setFirstResult((pageNum - 1) * pageSize);
listQuery.setMaxResults(pageSize);
List list = listQuery.list(); // 執行查詢
// 查詢總記錄數量
Query countQuery = getSession().createQuery(queryHelper.getCountQueryHql());
if (parameters != null) { // 設置參數
for (int i = 0; i < parameters.size(); i++) {
countQuery.setParameter(i, parameters.get(i));
}
}
Long count = (Long) countQuery.uniqueResult(); // 執行查詢
return new PageBean(pageNum, pageSize, count.intValue(), list);
}
}
調用案例
public class ForumServiceImpl extends DaoSupportImpl<Forum> implements ForumService{}