<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    數據加載中……
    在j2se環境中ejb3.0操作entity bean的通用類 PerfectEntityManager
    package com.vsc.study.ejb.util;

    import com.vsc.study.ejb.entitybean.Function;
    import java.lang.reflect.Method;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    import javax.persistence.EntityManager;
    import javax.persistence.EntityManagerFactory;
    import javax.persistence.Persistence;

    public class PerfectEntityManager {
        
        private EntityManagerFactory emf;
        private EntityManager em;
        
        public PerfectEntityManager() {
            emf = Persistence.createEntityManagerFactory("study-ejbPU");
            em = emf.createEntityManager();
        }
        
        public PerfectEntityManager(String utinName) {
            emf = Persistence.createEntityManagerFactory(utinName);
            em = emf.createEntityManager();
        }
        
        public Map<Integer, List> getCurrentResults(int currentPage, int pageSize,
                int maxResults, String querySql) {
            if (maxResults == 0) {
                maxResults = em.createQuery(querySql).getResultList().size();
            }
            List list = em.createQuery(querySql).setFirstResult(
                    (currentPage - 1) * pageSize).setMaxResults(pageSize)
                    .getResultList();
            HashMap<Integer, List> hashMap = new HashMap<Integer, List>();
            hashMap.put(maxResults, list);
            return hashMap;
        }
        
        public Map<Integer, List> getCurrentResults(int currentPage, int pageSize,
                int maxResults, Object object) {
            
            if (maxResults == 0) {
                maxResults = em.createQuery("from " + object.getClass())
                .getResultList().size();
            }
            List list = em.createQuery("from " + object.getClass()).setFirstResult(
                    (currentPage - 1) * pageSize).setMaxResults(pageSize)
                    .getResultList();
            HashMap<Integer, List> hashMap = new HashMap<Integer, List>();
            hashMap.put(maxResults, list);
            return hashMap;
        }
        
        String separator = " ";
        
        public String setEjbql(Object object, List<Ejbql> ejbqlList) {
            StringBuilder sb = new StringBuilder("select o from "
                    + object.getClass() + " as o where 1=1 ");
            for (Ejbql ejbql : ejbqlList) {
                if (ejbql == null) {
                    continue;
                }
                if (ejbql.getCloumns() == null) {
                    continue;
                }
                if (ejbql.getOperator() == null) {
                    continue;
                }
                if (ejbql.getValues() == null) {
                    continue;
                }
                sb.append(ejbql.getAndOr() + separator);
                sb.append("o." + ejbql.getCloumns());
                if (ejbql.getOperator().equals("like")) {
                    sb.append(separator + ejbql.getOperator() + separator);
                    sb.append("'%" + ejbql.getValues() + "%'" + separator);
                } else {
                    sb.append(ejbql.getOperator() + separator);
                    if (ejbql.getValues() instanceof String) {
                        sb.append("'" + ejbql.getValues() + "'" + separator);
                    } else {
                        sb.append(ejbql.getValues() + separator);
                    }
                }
            }
            return sb.toString();
        }
        
        public String setEjbql(String classname, List<Ejbql> ejbqlList) {
            StringBuilder sb = new StringBuilder("select o from " + classname
                    + " as o where 1=1 ");
            for (Ejbql ejbql : ejbqlList) {
                if (ejbql == null) {
                    continue;
                }
                if (ejbql.getCloumns() == null) {
                    continue;
                }
                if (ejbql.getOperator() == null) {
                    continue;
                }
                if (ejbql.getValues() == null) {
                    continue;
                }
                sb.append(ejbql.getAndOr() + separator);
                sb.append("o." + ejbql.getCloumns());
                if (ejbql.getOperator().equals("like")) {
                    sb.append(separator + ejbql.getOperator() + separator);
                    sb.append("'%" + ejbql.getValues() + "%'" + separator);
                } else {
                    sb.append(ejbql.getOperator() + separator);
                    if (ejbql.getValues() instanceof String) {
                        sb.append("'" + ejbql.getValues() + "'" + separator);
                    } else {
                        sb.append(ejbql.getValues() + separator);
                    }
                }
            }
            return sb.toString();
        }
        
        public int remove(Object object) {
            if (object == null)
                throw new NullPointerException();
            try {
                em.getTransaction().begin();
                em.remove(this.search(object));
                em.getTransaction().commit();
                em.close();
                emf.close();
                return 0;
            } catch (Exception e) {
                return -2;
            }
        }
        
        public int update(Object object) {
            if (object == null || this.getId(object) == null)
               throw new NullPointerException();
            Object obj = this.search(object);
            this.updateBean(object, obj);
            try {
                em.getTransaction().begin();
                em.merge(obj);
                em.getTransaction().commit();
                em.close();
                emf.close();
                return 0;
            } catch (Exception e) {
                return -1;
            }
        }
        
        public Object search(Object object) {
            if (object == null)
               throw new NullPointerException();
            try {
                Object obj = em.find(object.getClass(), this.getId(object));
                return obj;
            } catch (Exception e) {
                e.printStackTrace();
                return -1;
            }
        }
        
        public List searchAll(Object object) {
            if (object == null)
                throw new NullPointerException();
            try {
                em.getTransaction().begin();
                List list = em.createQuery("from " + object.getClass()).getResultList();
                em.getTransaction().commit();
                em.close();
                emf.close();
                return list;
            } catch (Exception e) {
                e.printStackTrace();
                return null;
            }
        }
        
        public Long insert(Object object) {
            try {
                em.getTransaction().begin();
                em.persist(object);
                em.getTransaction().commit();
                em.close();
                emf.close();
                return this.getId(object);
            } catch (Exception e) {
                e.printStackTrace();
                return -1l;
            }
        }
        
        public Long getId(Object object) {
            if (object == null)
                throw new NullPointerException();
            try {
                return (Long) object.getClass().getDeclaredMethod("getId").invoke(object);
            } catch (Exception e) {
                e.printStackTrace();
                return -5l;
            }
        }
        
        /**
         * obj is update Object
         *
         * @param object
         * @param obj
         */
        public void updateBean(Object object, Object obj) {
            try {
                Method[] methods = object.getClass().getDeclaredMethods();
                Method method;
                Object objectMethodValue;
                Object objMethodValue;
                for (int i = 0; i < methods.length; i++) {
                    if (methods[i].getName().trim().startsWith("get")) {
                        if (methods[i].invoke(object) == null) {
                            System.out
                                    .println("----------this field is null--------------");
                            continue;
                        }
                        objectMethodValue = methods[i].invoke(object);
                        objMethodValue = methods[i].invoke(obj);
                        if (objectMethodValue.equals(objMethodValue)) {
                            System.out
                                    .println("----------field is equals--------------");
                            continue;
                        }
                        method = obj.getClass().getDeclaredMethod(
                                methods[i].getName().trim().replaceFirst("g", "s"),
                                methods[i].getReturnType());
                        method.invoke(obj, objectMethodValue);
                        System.out.println("==============="
                                + methods[i].invoke(obj));
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    posted on 2008-02-25 15:26 java flex 結合 閱讀(701) 評論(0)  編輯  收藏 所屬分類: ejb 3.0

    主站蜘蛛池模板: 亚欧洲精品在线视频免费观看| 久久亚洲sm情趣捆绑调教| 国产又长又粗又爽免费视频| AA免费观看的1000部电影| www视频免费看| 久久国产乱子伦免费精品| 久久不见久久见免费视频7 | 中文字幕中韩乱码亚洲大片| 亚洲精品人成无码中文毛片| 免费在线一级毛片| 亚洲国产日韩成人综合天堂| ZZIJZZIJ亚洲日本少妇JIZJIZ | 67pao强力打造国产免费| 亚洲三级在线免费观看| 91频在线观看免费大全| 99在线视频免费观看视频 | 国产免费爽爽视频在线观看 | 亚洲AV日韩AV永久无码色欲| 亚洲av成人一区二区三区观看在线 | 2021在线观看视频精品免费| 精品熟女少妇a∨免费久久| 0588影视手机免费看片| 久久WWW色情成人免费观看| 色视频色露露永久免费观看| 国产一精品一aⅴ一免费| 亚洲七七久久精品中文国产| 亚洲精品成人片在线观看精品字幕 | 无码中文字幕av免费放| 日本免费一区尤物| 亚洲国产成人久久综合一区77| 国产成人精品日本亚洲专区61| 亚洲AV无码成人精品区蜜桃| 亚洲人成综合在线播放| 国产亚洲视频在线观看| 中文在线观看永久免费| 在线观看免费视频资源| 午夜色a大片在线观看免费| 亚洲中文字幕无码一区| 亚洲欧洲精品在线| 国产成人精品亚洲一区| APP在线免费观看视频|