<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

    主站蜘蛛池模板: 免费国产在线观看老王影院 | 亚洲人成网网址在线看| 国产一二三四区乱码免费| 免费看国产一级片| 国产成人亚洲精品蜜芽影院| 国产成人免费高清在线观看| 自拍偷自拍亚洲精品播放| 国产精品色午夜视频免费看| 噜噜噜亚洲色成人网站| 亚洲 综合 国产 欧洲 丝袜| 2022免费国产精品福利在线| 久久影院亚洲一区| 免费一级毛片在线播放视频| 亚洲综合一区二区精品导航| 2021精品国产品免费观看| 亚洲国产精品久久丫 | 国产美女无遮挡免费网站| 国产成人va亚洲电影| 亚洲一区二区三区免费| 国产免费网站看v片在线| 久久精品亚洲综合一品| 亚欧色视频在线观看免费| 日本亚洲精品色婷婷在线影院 | 亚洲国产精品专区在线观看| 一级毛片免费播放男男| 亚洲AV无码乱码在线观看裸奔| 久久大香香蕉国产免费网站| 亚洲福利视频一区二区三区| 毛片高清视频在线看免费观看| 边摸边脱吃奶边高潮视频免费| 国产亚洲成av人片在线观看| 免费看h片的网站| 亚洲AV色无码乱码在线观看 | 深夜国产福利99亚洲视频| 91成人免费观看在线观看| 亚洲日韩中文字幕天堂不卡| 国产一区二区免费在线| 免费成人在线视频观看| 亚洲av日韩专区在线观看| 国产亚洲精品一品区99热| 嫩草影院免费观看|