hibernamte中基础持久化类BaseDao及实现BaseDaoImpl

本文介绍了一个SSH(Spring + Struts + Hibernate)项目中的DAO层设计及其实现类,包括基本的增删改查功能,并提供了具体的代码示例。

package com.ssh.neb.dao;


import java.io.Serializable;
import java.util.Collection;
import java.util.List;


public interface BaseDao {

public Object find(String queryString,Object[] values);

public List findList(String queryString, Object[] values);

public List getAllObject(Class clazz);

public Object getObject(Class clazz, Serializable id);

public void saveObject(Object o);

public void removeObject(Class clazz, Serializable id);

public void removeObject(Object o);

public void removeAllObject(Collection collection);

public Object findBy(Class clazz , String name, Object value);


public List findLike(Class clazz, String name, String value);

public List findAllBy(Class clazz , String name, Object value);

public void flush();

}


以下是实现类,我感觉还行基本的增删改查都有,拿出来分享下:



package com.ssh.neb.daoImpl;

import java.io.Serializable;
import java.util.Collection;
import java.util.List;


import org.hibernate.Criteria;

import org.hibernate.criterion.Restrictions;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.ssh.neb.dao.BaseDao;


public class BaseDaoImpl extends HibernateDaoSupport implements BaseDao {

public List findAllBy(Class clazz, String name, Object value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.in(name, new Object[]{value}));
List list = cr.list();
return list;
}

public Object findBy(Class clazz, String name, Object value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.in(name, new Object[]{value}));
return cr.list().get(0);
}

public List findLike(Class clazz, String name, String value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.like(name, "%"+value+"%"));
return cr.list();
}

public void flush() {
getHibernateTemplate().flush();
}

public List getAllObject(Class clazz) {

return this.getHibernateTemplate().loadAll(clazz);

//return getHibernateTemplate().loadAll(clazz);

}

public Object getObject(Class clazz, Serializable id) {
return getHibernateTemplate().load(clazz, id);
}
public void removeAllObject(Collection collection) {
getHibernateTemplate().deleteAll(collection);
}

public void removeObject(Class clazz, Serializable id) {
Object object = this.getHibernateTemplate().load(clazz, id);
getHibernateTemplate().delete(object);
}

public void removeObject(Object o) {
getHibernateTemplate().delete(o);
}

public void saveObject(Object o) {
getHibernateTemplate().saveOrUpdate(o);
}

public Object find(String queryString, Object[] values) {
Object object = null;
List list = getHibernateTemplate().find(queryString, values);
if(list.size()>0)
object = list.get(0);
return object;
}

public List findList(String queryString, Object[] values) {
return getHibernateTemplate().find(queryString, values);
}



}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值