使用((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0]的实例

import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.List;

import org.apache.log4j.Logger;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

/**
 *  for now, our PK is only Integer type
 * 
 * 
 * **/
public abstract class BaseDao<T> extends HibernateDaoSupport {
	private final static Logger	logger				= Logger.getLogger( BaseDao.class );
	private final static String	FIND_BY_PKS			= "FROM %1$s WHERE %2$s in (:pks)";
	private final static String	FIND_BY_PROPERTY	= "FROM %1$s WHERE %2$s = ?";

	private Class<T>			entityClass;
	private String				entityName;
	private String				pkName;

	public abstract String getPkName();

	@SuppressWarnings( "unchecked" )
	public BaseDao() {
		entityClass = null;
		Type t = getClass().getGenericSuperclass();
		if ( t instanceof ParameterizedType ) {
			Type[] p = ( (ParameterizedType) t ).getActualTypeArguments();
			entityClass = (Class<T>) p[0];
		} else {
			entityClass = (Class<T>) Object.class;
		}

		entityName = entityClass.getSimpleName();
		pkName = getPkName();
	}

	public Class<T> getEntityClass(){
		return entityClass;
	}
	
	public T get(Integer id){
		return (T) getHibernateTemplate().get( entityClass, id );
	}

	public T save(T entity){
		getHibernateTemplate().save( entity );
		return entity;
	}

	public T saveOrUpdate(T entity){
		this.getHibernateTemplate().saveOrUpdate( entity );
		return entity;
	}

	public void delete(T entity){
		getHibernateTemplate().delete( entity );
	}

	public void loadAll(){
		getHibernateTemplate().loadAll( entityClass );
	}

	public void deleteAll(List<T> entities){
		getHibernateTemplate().deleteAll( entities );
	}

	@SuppressWarnings( "unchecked" )
	public List<T> findbyPKs(List<Integer> pks){
		String hql = String.format( FIND_BY_PKS, entityName, pkName );
		logger.debug( "HQL > " + hql );

		Session session = getSession();
		Query query = session.createQuery( hql );
		query.setParameterList( "pks", pks );

		return (List<T>) query.list();
	}

	@SuppressWarnings( "unchecked" )
	public List<T> findByProperty(String property,Object value){
		String hql = String.format( FIND_BY_PROPERTY, entityName, property );
		logger.debug( "HQL > " + hql );

		return (List<T>) getHibernateTemplate().find( hql, value );
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值