JPA EntityManager高级

原文链接:http://blog.csdn.net/han_yankun2009/article/details/45401935

 

面向对象的使用,抽象封装是家常必备,前两篇博客说道了基本的操作分别是:

  JPA EntitManager初体验

  JPA EntitManager进阶

这次咱们就对前两次的方法进行一个基本的抽象封装

一个方法为了应对不同类型的使用,同时为了类型安全,我们引入了泛型。泛型的加入,使方法更具有灵活性,同时也保证类型的安全,下面咱们就对基本的增,该查进行基本封装。

 

定义泛型类  

1 抽象类BaseEaoImpl<T>

[java] view plain copy print ? 在CODE上查看代码片
  1. Public abstract class BaseEaoImpl<T>  
  2.    
  3. {  
  4. //实体管理器引用  
  5. protected abstract EntityManager getEntityManager();  
  6. //反射对象  
  7. private Class<T> clazz;  
  8.   
  9. }  

先来看我们的最基本的几个方法吧

 

persist(Object)

find(Class<T>,object)

createQuery(String)

merge(TEntity)

 

要达到的要求是这四种方法适应所有的实体类型,所以抽象出来的Eao至少是子类的抽象,达到一个公用的效果

 

其次对于使用泛型的类型,对其操作还是要知道真实的类型,这里就用到了反射获取泛型真是类型

 1.1 构造函数反射获取泛型真是类型

        

[java] view plain copy print ? 在CODE上查看代码片
  1.    /** 
  2.  * 构造函数反射泛型对象真实类型 
  3.  */  
  4. public BaseEaoImpl() {  
  5.  ParameterizedType pType = (ParameterizedType) this.getClass().getGenericSuperclass();// 获取当前new的对象的泛型父类  
  6.  this.clazz = (Class<T>)pType.getActualTypeArguments()[0];// 获取类型参数的真是值,就是泛型参数的个数;  
  7.  className=  clazz.getSimpleName();  
  8.  System.out.println(clazz+"\n"+className);  
  9. }  

 

 1.2Save方法

  保存实体

[java] view plain copy print ? 在CODE上查看代码片
  1. public void save(T t) {  
  2.   
  3. getEntityManager().persist(t);  
  4.   
  5. }  

 

//批量保存实体

 

[java] view plain copy print ? 在CODE上查看代码片
  1. Publci booleansaveEntitys(List<T) entitys){  
  2.   
  3. //为了提升性能,我们对数据进行分批次的保存,手动控制更新到数据库  
  4.     boolean flag = false;  
  5.         try {  
  6.             // 每100条往数据库里写入一次,相对提升性能,此值可改变  
  7.             int batchSize = 100;  
  8.             int i = 0;  
  9.             for (T entity : entitys) {  
  10.                 getEntityManager().persist(entity);  
  11.                 i++;  
  12.                 if (i % batchSize == 0) {  
  13.                     getEntityManager().flush();  
  14.                     getEntityManager().clear();  
  15.                 }  
  16.             }  
  17.             flag = true;  
  18.             if (logger.isDebugEnabled()) {  
  19.                 logger.debug("Eao批量保存实体成功,"  
  20.                         + getEntityManager().getClass().getName());  
  21.             }  
  22.         } catch (Exception e) {  
  23.             flag = false;  
  24.             logger.error("Eao批量保存实体失败", e);  
  25.         }  
  26.         return flag;  
  27.   
  28. }  

 

 1.3 find方法

find方法,根据id或实体的某个属性查询等,这个时候就需要使用泛型具体类型了

 

[java] view plain copy print ? 在CODE上查看代码片
  1. //根据主键id查询  
  2.  public T findEntityById(Serializable id){  
  3.    
  4.    return getEntityManager().find(clazz, id);  
  5. }  

当然了还可以传入集合Id

[java] view plain copy print ? 在CODE上查看代码片
  1. //根据id集合查询实体集合  
  2. public List<T> getByIds(List<String> ids) {  
  3.         return getEntityManager().createQuery(//  
  4.                 "FROM " + className + "WHERE id in (:ids)")//  
  5.                 .setParameter("ids", ids)//  
  6.                 .list();  
  7.     }  

 

1.4 更新merge

//更新实体 ---留意级联更新的效果
[java] view plain copy print ? 在CODE上查看代码片
  1. public boolean updateEntity(T entity) {  
  2.     boolean flag = false;  
  3.     try {  
  4.         getEntityManager().merge(entity);  
  5.         flag = true;  
  6.     } catch (Exception e) {  
  7.         flag = false;  
  8.         logger.error("Eao更新实体失败", e);  
  9.     }  
  10.     return flag;  
  11. }  

 

1.5 createQuery

createQuery的用法博大精深,以上的任何一个用户几乎都可以用creaQuery替代

 

如: queryByHql

参数hqlhql语句,

Maphql中的参数与值

 

[java] view plain copy print ? 在CODE上查看代码片
  1. public List queryByHql(final String hql,  
  2.             final Map<Serializable, Serializable> map) {  
  3.         if (null == hql || "".equals(hql)) {  
  4.             return null;  
  5.         }  
  6.         try {  
  7.             Query query = getEntityManager().createQuery(hql);  
  8.             for (Serializable key : map.keySet()) {  
  9.                 query.setParameter((String) key, map.get(key));  
  10.             }  
  11.             List list = query.getResultList();  
  12.             if (logger.isDebugEnabled()) {  
  13.                 logger.debug("Eao根据hql语句查询实体集合成功,"  
  14.                         + getEntityManager().getClass().getName());  
  15.             }  
  16.   
  17.             return list;  
  18.   
  19.         } catch (Exception e) {  
  20.             logger.error("Eao根据hql语句查询实体集合失败", e);  
  21.             return null;  
  22.         }  
  23.     }  

实例:

[java] view plain copy print ? 在CODE上查看代码片
  1. public List findSmallQuesID(String paperID,String questionTypeId){  
  2.     //参数hql语句  
  3.     String hql = "From PaperSecond where paperID =:paperID AND questionTypeID=:questionTypeId";  
  4.     //参数hal参数与值  
  5.     Map<Serializable, Serializable> map = new HashMap<Serializable, Serializable>();  
  6.     map.put("paperID", paperID);  
  7.     map.put("questionTypeId", questionTypeId);  
  8.     List<PaperDetail> paperSecondList = paperSecondEao.queryByHql(hql, map);  
  9.     return paperSecondList;  
  10. }  

//根据条件更新 

[java] view plain copy print ? 在CODE上查看代码片
  1. //根据条件更新  
  2. //String variable(要更新的字段), String condition(更新的条件),Object... args  
  3. public boolean updateByCondition(String variable, String condition,  
  4.             Object... args) {  
  5.         boolean flag = false;  
  6.         qltry {  
  7.             Query query = getEntityManager().createQuery(  
  8.                     "update " + clazz.getSimpleName() + " as o set " + variable  
  9.                             + " " + condition);  
  10.             for (int i = 0; i < args.length; i++) {  
  11.                 query.setParameter(i + 1, args[i]);  
  12.             }  
  13.             query.executeUpdate();  
  14.             flag = true;  
  15.             if (logger.isDebugEnabled()) {  
  16.                 logger.debug("Eao根据条件更新实体成功,"  
  17.                         + getEntityManager().getClass().getName());  
  18.             }  
  19.         } catch (Exception e) {  
  20.             flag = false;  
  21.             logger.error("Eao根据条件更新实体失败", e);  
  22.         }  
  23.         return flag;  
  24.     }  

实例:    

 

[java] view plain copy print ? 在CODE上查看代码片
  1.   String variable="studentName=?,sex=?";//要修改的字段,参数用?  
  2. String condition="wherestudentCode=?";//条件  
  3. flag= studentBean.updateByCondition(variable, condition, "参数1","参数2","参数3");  
  4.    

 

总结: 

通过以上几个小的实例我们认识到,几个小小的方法,可以引伸出不少的变化,但是重点还是在于不断的总结,不断的抽象,尤其在于对hql语句上。

你可能感兴趣的:(JPA EntityManager高级)