求一个hibernate4封装好了的baseDao代码,带分页的。

请给出baseDao,给出Page页面。... 请给出baseDao,给出Page页面。 展开
 我来答
534756893
推荐于2017-11-26 · TA获得超过103个赞
知道小有建树答主
回答量:82
采纳率:0%
帮助的人:41.6万
展开全部
package com.hillpool.common;

import java.io.Serializable;
import java.lang.reflect.ParameterizedType;
import java.sql.SQLException;
import java.util.Collection;
import java.util.List;
import java.util.Map;

import javax.persistence.UniqueConstraint;

import org.apache.commons.lang.StringUtils;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Example;
import org.hibernate.criterion.Projections;
import org.hibernate.metadata.ClassMetadata;
import org.hibernate.type.Type;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.orm.hibernate4.HibernateCallback;
import org.springframework.orm.hibernate4.HibernateTemplate;
import org.springframework.stereotype.Repository;

import com.hillpool.czbbb.model.Product2CarModelRelationItem;

/**
* @author wudw
* 2014年3月18日 上午11:49:03
*/

public class BaseDaoHibImpl<T> implements BaseDao<T> {
@Autowired
private HibernateTemplate hibernateTemplate;
protected SessionFactory sessionFactory;

@Override
public T add(T t) throws Exception {
hibernateTemplate.save(t);
return t;
}

@Override
public void update(T t) throws Exception {
hibernateTemplate.update(t);
}

@Override
public void merge(T t) throws Exception {
hibernateTemplate.merge(t);
}
@Override
public void delete(T t) throws Exception {
hibernateTemplate.delete(t);
}

@Override
public T get(Class<T> entityClass, Serializable id) {
T ret = (T) hibernateTemplate.get(entityClass, id);
return ret;
}
@Override
public void deleteById(Serializable id) throws Exception {
T ret = this.get(this.getEntityClass(), id);
if (ret != null){
delete(ret);
}
}

// @Override
// public List<T> findAll() throws Exception {
// String hql = "from "+this.getEntityClassName();
// return this.queryForList(hql, null).getResultList();
//
// }
// @Override
// public PageList<T> findAll(PageBean pageBean) throws Exception {
// String hql = "from "+this.getEntityClassName();
// return (PageList<T>)this.queryForList(hql, pageBean);
//
// }
@SuppressWarnings("unchecked")
@Override
public T findById(Serializable id) throws Exception {
return (T)hibernateTemplate.get(getEntityClassName(), id);

}
// public T findForObject(final T entity){
// PageList<T> pageList = findForList(entity, null);
// if(pageList != null && pageList.getResultList() != null && !pageList.getResultList().isEmpty()){
// return pageList.get(0);
// }
// return null;
// }
// @SuppressWarnings("unchecked")
// public PageList<T> findForList(final T entity, final PageBean pageBean){
// DetachedCriteria detachedCriteria = DetachedCriteria.forClass(entity.getClass()).add(Example.create(entity));
// List<?> list = null;
// if(!PageBean.isEmpty(pageBean)) {
// list = hibernateTemplate.findByCriteria(detachedCriteria, pageBean.getLimit(), pageBean.getOffset());
// Criteria criteria = detachedCriteria.getExecutableCriteria(hibernateTemplate.getSessionFactory().getCurrentSession());
// Long totalCount = (Long) criteria.setProjection(Projections.rowCount()).uniqueResult();
// pageBean.setTotalCount(totalCount);
// } else {
// list =hibernateTemplate.findByCriteria(detachedCriteria);
// }
// return new PageList<T>((List<T>)list, pageBean);
// }

//

// /**
// * 单对象查询
//
// * @param hql
// * @param objects
// * @return
// * 2014年3月21日 下午2:08:26
// */
// protected T queryForObject(final String hql, final Object ... objects){
// PageList<T> pageList = this.queryForList(hql, null, null, objects);
// if(pageList != null && pageList.isEmpty()){
// return pageList.get(0);
// }
// return null;
// }

/**
* 执行查询结果集

* @param hql
* @param page
* @param pageSize
* @param objects
* @return
* 2014年3月21日 下午2:08:09
*/
// protected PageList<T> queryForList(final String hql, final PageBean pageBean, final Object ... objects ){
// return hibernateTemplate.execute(new HibernateCallback<PageList<T>>() {
// @SuppressWarnings("unchecked")
// @Override
// public PageList<T> doInHibernate(Session session) throws HibernateException {
// Query createQuery = createQuery(session, hql, objects);
// List<T> list = null;
// if(pageBean != null){
// createQuery.setFirstResult(pageBean.getLimit());
// createQuery.setMaxResults(pageBean.getOffset());
// list = createQuery.list();
// String countHql = null;
// if(StringUtils.containsIgnoreCase(hql, "from")){
// countHql = "select count(0) "+StringUtils.substring(hql, StringUtils.indexOfIgnoreCase(hql, "from"));
// }
// Query countQuery = createQuery(session, countHql, objects);
// List<Long> countList = countQuery.list();
// Long totalCount = 0L;
// if(countList != null && countList.size() > 0){
// totalCount =countList.get(0);
// }
// pageBean.setTotalCount(totalCount);;
// } else {
// list = createQuery.list();
// }
// return new PageList<T>(list, pageBean);
// }
//
// });
// }

/**
* 执行查询以外的操作
* @param hql
* @param objs
* 2014年3月21日 上午11:42:19
*/
protected Integer executeUpdate(final String hql, final Object ... objects){
return hibernateTemplate.execute(new HibernateCallback<Integer>() {
@Override
public Integer doInHibernate(Session session) throws HibernateException {
Query createQuery = createQuery(session, hql, objects);
return createQuery.executeUpdate();
}
});
}
/**
* 得到泛型中的实体类型

* @return
* 2014年3月18日 下午2:32:35
*/
protected Class<T> getEntityClass(){
@SuppressWarnings("unchecked")
Class<T> entityClass = (Class<T>)((ParameterizedType)getClass().getGenericSuperclass()).getActualTypeArguments()[0];
return entityClass;
}
/**
* @Author: Charles
* @Description: 获取表主键类型
* @param clazz
* @return Type:
*/
public Type getPkType() {
ClassMetadata meta = hibernateTemplate.getSessionFactory().getClassMetadata(getEntityClass());
return meta.getIdentifierType();
}
/**
* 获取主键名

* @return
* 2014年3月21日 下午2:42:49
*/
public String getPkColunmName(){
ClassMetadata meta = hibernateTemplate.getSessionFactory().getClassMetadata(getEntityClass());
return meta.getIdentifierPropertyName();
}

/**
* 获取实体类型名

* @return
* 2014年3月18日 下午2:33:01
*/
protected String getEntityClassName() {
ClassMetadata meta = hibernateTemplate.getSessionFactory().getClassMetadata(getEntityClass());
return meta.getEntityName();
}
/**
* 返回设置好参数的查询对象

* @param query
* @param objects
* 2014年3月21日 下午2:07:56
*/
private Query createQuery(Session session,String hql, Object ... objects) {
System.out.println(hql);
Query query = session.createQuery(hql);
if (objects != null){
for (int i = 0; i < objects.length; i++) {
query.setParameter(i, objects[i]);
}
}
return query;
}

@SuppressWarnings("unchecked")
@Override
public List<T> find(String hql, String[] paramNames, Object[] values) {
List<T> ret = null;
ret = (List<T>)hibernateTemplate.findByNamedParam(hql, paramNames,values);
return ret;
}

@SuppressWarnings("unchecked")
@Override
public List find(final String hql, final Map<String, Object> param, final int pageNo,
final int pageSize) {
return hibernateTemplate.execute(new HibernateCallback<List>() {
@Override
public List doInHibernate(Session session) throws HibernateException {
String shql=hql;
if (pageNo == 0&&pageSize!=0) {
String sql = "select count(e) ";
shql = sql + hql;
}
Query query = session.createQuery(shql);
if (param != null && param.size() > 0) {
for (String property : param.keySet()) {
if (param.get(property) instanceof List){
query.setParameterList(property, (Collection)param.get(property));
}else{
query.setParameter(property,
param.get(property));
}
}
}
if (pageNo != 0 && pageSize != 0) {
query.setFirstResult((pageNo - 1) * pageSize);
query.setMaxResults(pageSize);
}
List list = null;
try{
list = query.list();
}catch (HibernateException e) {
e.printStackTrace();
throw e;
}
return list;
}
});

}

@SuppressWarnings("unchecked")
@Override
public List<T> find(final String hql,final Map<String, Object> param) {
Session session = hibernateTemplate.getSessionFactory().getCurrentSession();
Query query = session.createQuery(hql);
if (param != null && param.size() > 0) {
for (String property : param.keySet()) {
query.setParameter(property,param.get(property));
}
}
return query.list();
/*return hibernateTemplate.execute(new HibernateCallback<List>() {
@Override
public List<T> doInHibernate(Session session) throws HibernateException {
Query query = session.createQuery(hql);
if (param != null && param.size() > 0) {
for (String property : param.keySet()) {
query.setParameter(property,param.get(property));
}
}
return query.list();
}
});*/

}
//
// @Override
// public List<T> find(String hql) {
// return this.queryForList(hql, null).getResultList();
// }
//
// @SuppressWarnings("unchecked")
// @Override
// public List findHql(String hql) {
// return this.queryForList(hql, null).getResultList();
// }

@SuppressWarnings("unchecked")
@Override
public Object getById(Class c, Serializable id) {
Object ret = hibernateTemplate.get(c, id);
return ret;
}

@SuppressWarnings("unchecked")
@Override
public List findHql(final String hql, final Map<String, Object> param) {
return hibernateTemplate.execute(new HibernateCallback<List>() {
@Override
public List<T> doInHibernate(Session session) throws HibernateException {
Query query = session.createQuery(hql);
if (param != null && param.size() > 0) {
for (String property : param.keySet()) {
query.setParameter(property,param.get(property));
}
}
return query.list();
}
});
}

@SuppressWarnings("unchecked")
@Override
public int updateHql(String hql) {
return executeUpdate(hql, null);
}

public SessionFactory getSessionFactory() {
return sessionFactory;
}

public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}

@Override
public List<T> find(String hql) {
List<T> list = this.find(hql, null);
return list;
}

@Override
public List findHql(String hql) {
List list = findHql(hql, null);
return list;
}

}
公司现在公用的,也许不是你想要的,不过改改应该就是你想要的了
帐号已注销
2016-12-29 · 超过54用户采纳过TA的回答
知道小有建树答主
回答量:201
采纳率:0%
帮助的人:93.2万
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友60ba0a5
2014-11-13 · TA获得超过231个赞
知道小有建树答主
回答量:544
采纳率:100%
帮助的人:213万
展开全部
已经解决,遇到过相关问题的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
myqq5101437
2014-11-13 · TA获得超过277个赞
知道小有建树答主
回答量:1575
采纳率:40%
帮助的人:224万
展开全部
我有 杂发给你呢 你家我
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式