web中的dao模板

在web项目中  我们可能会针对每一个实体写一个dao    针对每一个dao写一个实现 

这样重复的代码很多 ,如果项目中有一千个实体 ,是不是要写一千个dao以及一千个dao的实现  

对此本人写了一个basedao   以及他的实现  以后做项目 只要拷贝一份就可以 

代码如下 

Java代码   收藏代码
  1. public interface DAO {  
  2.     /** 
  3.      * 获取记录总数 
  4.      * @param entityClass 实体类 
  5.      * @return 
  6.      */  
  7.     public <T> long getCount(Class<T> entityClass);  
  8.     /** 
  9.      * 清除一级缓存的数据 
  10.      */  
  11.     public void clear();  
  12.     /** 
  13.      * 保存实体 
  14.      * @param entity 实体id 
  15.      */  
  16.     public void save(Object entity);  
  17.     /** 
  18.      * 更新实体 
  19.      * @param entity 实体id 
  20.      */  
  21.     public void update(Object entity);  
  22.     /** 
  23.      * 删除实体 
  24.      * @param entityClass 实体类 
  25.      * @param entityid 实体id 
  26.      */  
  27.     public <T> void delete(Class<T> entityClass, Object entityid);  
  28.     /** 
  29.      * 删除实体 
  30.      * @param entityClass 实体类 
  31.      * @param entityids 实体id数组 
  32.      */  
  33.     public <T> void delete(Class<T> entityClass, Object[] entityids);  
  34.     /** 
  35.      * 获取实体 
  36.      * @param <T> 
  37.      * @param entityClass 实体类 
  38.      * @param entityId 实体id 
  39.      * @return 
  40.      */  
  41.     public <T> T find(Class<T> entityClass, Object entityId);  
  42.     /** 
  43.      * 获取分页数据 
  44.      * @param <T> 
  45.      * @param entityClass 实体类 
  46.      * @param firstindex 开始索引 
  47.      * @param maxresult 需要获取的记录数 
  48.      * @return 
  49.      */  
  50.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult  
  51.             , String wherejpql, Object[] queryParams,LinkedHashMap<String, String> orderby);  
  52.       
  53.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult  
  54.             , String wherejpql, Object[] queryParams);  
  55.       
  56.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult  
  57.             , LinkedHashMap<String, String> orderby);  
  58.       
  59.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult);  
  60.       
  61.     public <T> QueryResult<T> getScrollData(Class<T> entityClass);  
  62. }  



daoSuport是结合ejb3.0写的    用泛型实现 

Java代码   收藏代码
  1. import java.beans.Introspector;  
  2. import java.beans.PropertyDescriptor;  
  3. import java.lang.reflect.Method;  
  4. import java.util.LinkedHashMap;  
  5.   
  6. import javax.persistence.EmbeddedId;  
  7. import javax.persistence.Entity;  
  8. import javax.persistence.EntityManager;  
  9. import javax.persistence.PersistenceContext;  
  10. import javax.persistence.Query;  
  11.   
  12. import org.springframework.transaction.annotation.Propagation;  
  13. import org.springframework.transaction.annotation.Transactional;  
  14.   
  15. import com.itcast.bean.QueryResult;  
  16.   
  17. @Transactional  
  18. public abstract class DaoSupport implements DAO{  
  19.     @PersistenceContext protected EntityManager em;  
  20.       
  21.     public void clear(){  
  22.         em.clear();  
  23.     }  
  24.   
  25.     public <T> void delete(Class<T> entityClass,Object entityid) {  
  26.         delete(entityClass, new Object[]{entityid});  
  27.     }  
  28.   
  29.     public <T> void delete(Class<T> entityClass,Object[] entityids) {  
  30.         for(Object id : entityids){  
  31.             em.remove(em.getReference(entityClass, id));  
  32.         }  
  33.     }  
  34.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  35.     public <T> T find(Class<T> entityClass, Object entityId) {  
  36.         return em.find(entityClass, entityId);  
  37.     }  
  38.   
  39.     public void save(Object entity) {  
  40.         em.persist(entity);  
  41.     }  
  42.       
  43.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  44.     public <T> long getCount(Class<T> entityClass) {  
  45.         return (Long)em.createQuery("select count("+ getCountField(entityClass) +") from "+ getEntityName(entityClass)+ " o").getSingleResult();  
  46.     }  
  47.       
  48.     public void update(Object entity) {  
  49.         em.merge(entity);  
  50.     }  
  51.       
  52.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  53.     public <T> QueryResult<T> getScrollData(Class<T> entityClass,  
  54.             int firstindex, int maxresult, LinkedHashMap<String, String> orderby) {  
  55.         return getScrollData(entityClass,firstindex,maxresult,null,null,orderby);  
  56.     }  
  57.       
  58.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  59.     public <T> QueryResult<T> getScrollData(Class<T> entityClass,  
  60.             int firstindex, int maxresult, String wherejpql, Object[] queryParams) {  
  61.         return getScrollData(entityClass,firstindex,maxresult,wherejpql,queryParams,null);  
  62.     }  
  63.       
  64.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  65.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult) {  
  66.         return getScrollData(entityClass,firstindex,maxresult,null,null,null);  
  67.     }  
  68.       
  69.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  70.     public <T> QueryResult<T> getScrollData(Class<T> entityClass) {  
  71.         return getScrollData(entityClass, -1, -1);  
  72.     }  
  73.   
  74.     @SuppressWarnings("unchecked")  
  75.     @Transactional(readOnly=true,propagation=Propagation.NOT_SUPPORTED)  
  76.     public <T> QueryResult<T> getScrollData(Class<T> entityClass, int firstindex, int maxresult  
  77.             , String wherejpql, Object[] queryParams,LinkedHashMap<String, String> orderby) {  
  78.         QueryResult qr = new QueryResult<T>();  
  79.         String entityname = getEntityName(entityClass);  
  80.         Query query = em.createQuery("select o from "+ entityname+ " o "+(wherejpql==null"""where "+ wherejpql)+ buildOrderby(orderby));  
  81.         setQueryParams(query, queryParams);  
  82.         if(firstindex!=-1 && maxresult!=-1) query.setFirstResult(firstindex).setMaxResults(maxresult);  
  83.         qr.setResultlist(query.getResultList());  
  84.         query = em.createQuery("select count("+ getCountField(entityClass)+ ") from "+ entityname+ " o "+(wherejpql==null"""where "+ wherejpql));  
  85.         setQueryParams(query, queryParams);  
  86.         qr.setTotalrecord((Long)query.getSingleResult());  
  87.         return qr;  
  88.     }  
  89.       
  90.     protected void setQueryParams(Query query, Object[] queryParams){  
  91.         if(queryParams!=null && queryParams.length>0){  
  92.             for(int i=0; i<queryParams.length; i++){  
  93.                 query.setParameter(i+1, queryParams[i]);  
  94.             }  
  95.         }  
  96.     }  
  97.     /** 
  98.      * 组装order by语句 
  99.      * @param orderby 
  100.      * @return 
  101.      */  
  102.     protected String buildOrderby(LinkedHashMap<String, String> orderby){  
  103.         StringBuffer orderbyql = new StringBuffer("");  
  104.         if(orderby!=null && orderby.size()>0){  
  105.             orderbyql.append(" order by ");  
  106.             for(String key : orderby.keySet()){  
  107.                 orderbyql.append("o.").append(key).append(" ").append(orderby.get(key)).append(",");  
  108.             }  
  109.             orderbyql.deleteCharAt(orderbyql.length()-1);  
  110.         }  
  111.         return orderbyql.toString();  
  112.     }  
  113.     /** 
  114.      * 获取实体的名称 
  115.      * @param <T> 
  116.      * @param entityClass 实体类 
  117.      * @return 
  118.      */  
  119.     protected <T> String getEntityName(Class<T> entityClass){  
  120.         String entityname = entityClass.getSimpleName();  
  121.         Entity entity = entityClass.getAnnotation(Entity.class);  
  122.         if(entity.name()!=null && !"".equals(entity.name())){  
  123.             entityname = entity.name();  
  124.         }  
  125.         return entityname;  
  126.     }  
  127.       
  128.     protected <T> String getCountField(Class<T> clazz){  
  129.         String out = "o";  
  130.         try {  
  131.             PropertyDescriptor[] propertyDescriptors = Introspector.getBeanInfo(clazz).getPropertyDescriptors();  
  132.             for(PropertyDescriptor propertydesc : propertyDescriptors){  
  133.                 Method method = propertydesc.getReadMethod();  
  134.                 if(method!=null && method.isAnnotationPresent(EmbeddedId.class)){                     
  135.                     PropertyDescriptor[] ps = Introspector.getBeanInfo(propertydesc.getPropertyType()).getPropertyDescriptors();  
  136.                     out = "o."+ propertydesc.getName()+ "." + (!ps[1].getName().equals("class")? ps[1].getName(): ps[0].getName());  
  137.                     break;  
  138.                 }  
  139.             }  
  140.         } catch (Exception e) {  
  141.             e.printStackTrace();  
  142.         }  
  143.         return out;  
  144.     }  
  145. }  


业务层service  只要继承自DaoSupport就能实现所有的方法 

Java代码   收藏代码
  1. public class BrandServiceBean extends DaoSupport implements BrandService {  
  2.   
  3.     @Override  
  4.     public void save(Object entity) {  
  5.         ((Brand)entity).setCode(UUID.randomUUID().toString());  
  6.         super.save(entity);  
  7.     }  
  8.       
  9. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值