BaseDaoImpl

package dao.impl;

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

import org.hibernate.criterion.DetachedCriteria;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.HibernateTemplate;

import dao.BaseDao;

public class BaseDaoImpl<T> implements BaseDao<T> {
    private HibernateTemplate hibernateTemplate;
    private Class<T> cls;

    public HibernateTemplate getHibernateTemplate() {
        return hibernateTemplate;
    }

    public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
        this.hibernateTemplate = hibernateTemplate;
    }
    
    public BaseDaoImpl() {
        cls = (Class<T>) ((ParameterizedType) this.getClass()
                        .getGenericSuperclass())
                        .getActualTypeArguments()[0];
    }

    @Override
    public void save(T o) {
        this.getHibernateTemplate().save(o);
    }

    @Override
    public void update(T o) {
        this.getHibernateTemplate().update(o);
    }

    @Override
    public void delete(T o) {
        this.getHibernateTemplate().delete(o);
    }

    @Override
    public T get(Serializable id) {
        return this.getHibernateTemplate().get(cls, id);
    }
    @Override
    public void saveOrUpdate(T o) {
        this.getHibernateTemplate().saveOrUpdate(o);
    }

    @Override
    public T merge(T o) {
        return this.getHibernateTemplate().merge(o);
    }

    @Override
    public Integer deleteAll(final Object[] ids) {
        // delete from Xxx where id in(:ids)
        // Query executeUpdate() int
        return this.getHibernateTemplate().execute(
            new HibernateCallback<Integer>() {
                public Integer doInHibernate(org.hibernate.Session arg0)
                        throws org.hibernate.HibernateException ,java.sql.SQLException {
                    return arg0.createQuery(
                                "delete from " + cls.getSimpleName()
                                + " x where x.id in(:ids)")
                            .setParameterList("ids", ids)
                            .executeUpdate();
                }
            }
        );
    }

    @Override
    public void deleteAll(Collection<T> objs) {
        this.getHibernateTemplate().deleteAll(objs);
    }

    @Override
    public List<T> findAll() {
        return this.getHibernateTemplate()
                .find("from " + cls.getSimpleName());
    }

    @Override
    public List<T> findForPage(DetachedCriteria conds, int pageNo, int pageSize) {
        return this.getHibernateTemplate()
                .findByCriteria(conds, (pageNo - 1) * pageSize, pageSize);
    }

    @Override
    public Integer getTotalCount(DetachedCriteria conds) {
        return (Integer) this.getHibernateTemplate()
                    .findByCriteria(conds).get(0);
    }

    @Override
    public List<T> findByCriteria(DetachedCriteria conds) {
        return this.getHibernateTemplate().findByCriteria(conds);
    }

    @Override
    public List<T> findByExample(T o) {
        return this.getHibernateTemplate().findByExample(o);
    }

    @Override
    public List<T> find(String hql, Object... params) {
        return this.getHibernateTemplate().find(hql, params);
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值