Demora ao retornar um cadastro

10 respostas
philipe

Boa tarde galera!! Estou com uma dúvida aqui…

Fiz um trabalho de faculdade aqui usando Primefaces que cadastra e consulta, que nada mais eh do que uma Datatable.
Tudo funciona ok, sem problemas… Mas quando realizo um cadastro, ele demora muito até atualizar os dados do datatable…

O que pode ser isso?

10 Respostas

henriqueluz

O que voce ta usando no seu projeto alem do primefaces?
Como está a consulta do datatable?

De mais informações.

philipe

Cara, é um projeto bem simples mesmo, utilizando a funcionalidade do NetBeans: Novo -> Páginas JSF de Entidade…

Bem, não mudei basicamente nada!! Tanto que quando eu uso as páginas geradas pelo próprio NetBeans, o retorno é rápido, mas quando utilizo o datatable, tem essa lentidão de retorno…
O banco que utilizo é o Oracle 10g e o servidor é o GlassFish…

FernandoFranzini

Pode ser muitas coisas…

  • Gasto com o perfil JEE do glasfish…
  • Pool de conexão
  • Resposta do banco de dados…
E

Tive problemas no início quando eu criava as Controladoras das Entidades pelo Netbeans pois criava a EntityManagerFactory automaticamente em todas classes. Para resolver criei uma classe EntityManagerFactory e nas Controladoras eu acesso chamo ela somente. Melhorou bastante o desempenho.

Vlw

philipe

edudebom:
Tive problemas no início quando eu criava as Controladoras das Entidades pelo Netbeans pois criava a EntityManagerFactory automaticamente em todas classes. Para resolver criei uma classe EntityManagerFactory e nas Controladoras eu acesso chamo ela somente. Melhorou bastante o desempenho.

Vlw

Como assim?? Tem como postar um exemplo??

E

Poste o código das suas Entidades e Controladoras.

philipe

Entidade GrupoEquipamento

@Entity
@Table(name = "GRUPOEQUIPAMENTO", catalog = "", schema = "SACA")
@XmlRootElement
@NamedQueries({
    @NamedQuery(name = "Grupoequipamento.findAll", query = "SELECT g FROM Grupoequipamento g"),
    @NamedQuery(name = "Grupoequipamento.findByIdgrupoequipamento", query = "SELECT g FROM Grupoequipamento g WHERE g.idgrupoequipamento = :idgrupoequipamento"),
    @NamedQuery(name = "Grupoequipamento.findByDescrgrupoequipamento", query = "SELECT g FROM Grupoequipamento g WHERE g.descrgrupoequipamento = :descrgrupoequipamento")})
public class Grupoequipamento implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @Basic(optional = false)
    @NotNull
    @Column(name = "IDGRUPOEQUIPAMENTO", nullable = false)
    private Integer idgrupoequipamento;
    @Basic(optional = false)
    @NotNull
    @Size(min = 1, max = 30)
    @Column(name = "DESCRGRUPOEQUIPAMENTO", nullable = false, length = 30)
    private String descrgrupoequipamento;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "idgrupoequipamento")
    private List<Equipamento> equipamentoList;

    public Grupoequipamento() {
    }

    public Grupoequipamento(Integer idgrupoequipamento) {
        this.idgrupoequipamento = idgrupoequipamento;
    }

    public Grupoequipamento(Integer idgrupoequipamento, String descrgrupoequipamento) {
        this.idgrupoequipamento = idgrupoequipamento;
        this.descrgrupoequipamento = descrgrupoequipamento;
    }
                            
                                       // getters & setters

E seu controlador

@ManagedBean(name = "grupoequipamentoController")
@SessionScoped
public class GrupoequipamentoController implements Serializable {

    private Grupoequipamento current;
    private DataModel items = null;
    @EJB
    private facade.GrupoequipamentoFacade ejbFacade;
    private PaginationHelper pagination;
    private int selectedItemIndex;

    public GrupoequipamentoController() {
    }

    public Grupoequipamento getSelected() {
        if (current == null) {
            current = new Grupoequipamento();
            selectedItemIndex = -1;
        }
        return current;
    }

    private GrupoequipamentoFacade getFacade() {
        return ejbFacade;
    }

    public PaginationHelper getPagination() {
        if (pagination == null) {
            pagination = new PaginationHelper(10) {

                @Override
                public int getItemsCount() {
                    return getFacade().count();
                }

                @Override
                public DataModel createPageDataModel() {
                    return new ListDataModel(getFacade().findRange(new int[]{getPageFirstItem(), getPageFirstItem() + getPageSize()}));
                }
            };
        }
        return pagination;
    }

    public String prepareList() {
        recreateModel();
        return "List";
    }

    public String prepareView() {
        current = (Grupoequipamento) getItems().getRowData();
        selectedItemIndex = pagination.getPageFirstItem() + getItems().getRowIndex();
        return "View";
    }

    public String prepareCreate() {
        current = new Grupoequipamento();
        selectedItemIndex = -1;
        return "Create";
    }

    public String create() {
        try {
            getFacade().create(current);
            JsfUtil.addSuccessMessage(ResourceBundle.getBundle("/Bundle").getString("GrupoequipamentoCreated"));
            return prepareCreate();
        } catch (Exception e) {
            JsfUtil.addErrorMessage(e, ResourceBundle.getBundle("/Bundle").getString("PersistenceErrorOccured"));
            return null;
        }
    }

    public String prepareEdit() {
        current = (Grupoequipamento) getItems().getRowData();
        selectedItemIndex = pagination.getPageFirstItem() + getItems().getRowIndex();
        return "Edit";
    }

    public String update() {
        try {
            getFacade().edit(current);
            JsfUtil.addSuccessMessage(ResourceBundle.getBundle("/Bundle").getString("GrupoequipamentoUpdated"));
            return "View";
        } catch (Exception e) {
            JsfUtil.addErrorMessage(e, ResourceBundle.getBundle("/Bundle").getString("PersistenceErrorOccured"));
            return null;
        }
    }

    public String destroy() {
        current = (Grupoequipamento) getItems().getRowData();
        selectedItemIndex = pagination.getPageFirstItem() + getItems().getRowIndex();
        performDestroy();
        recreateModel();
        return "List";
    }

    public String destroyAndView() {
        performDestroy();
        recreateModel();
        updateCurrentItem();
        if (selectedItemIndex >= 0) {
            return "View";
        } else {
            // all items were removed - go back to list
            recreateModel();
            return "List";
        }
    }

    private void performDestroy() {
        try {
            getFacade().remove(current);
            JsfUtil.addSuccessMessage(ResourceBundle.getBundle("/Bundle").getString("GrupoequipamentoDeleted"));
        } catch (Exception e) {
            JsfUtil.addErrorMessage(e, ResourceBundle.getBundle("/Bundle").getString("PersistenceErrorOccured"));
        }
    }

    private void updateCurrentItem() {
        int count = getFacade().count();
        if (selectedItemIndex >= count) {
            // selected index cannot be bigger than number of items:
            selectedItemIndex = count - 1;
            // go to previous page if last page disappeared:
            if (pagination.getPageFirstItem() >= count) {
                pagination.previousPage();
            }
        }
        if (selectedItemIndex >= 0) {
            current = getFacade().findRange(new int[]{selectedItemIndex, selectedItemIndex + 1}).get(0);
        }
    }

    public DataModel getItems() {
        if (items == null) {
            items = getPagination().createPageDataModel();
        }
        return items;
    }

    private void recreateModel() {
        items = null;
    }

    public String next() {
        getPagination().nextPage();
        recreateModel();
        return "List";
    }

    public String previous() {
        getPagination().previousPage();
        recreateModel();
        return "List";
    }

    public SelectItem[] getItemsAvailableSelectMany() {
        return JsfUtil.getSelectItems(ejbFacade.findAll(), false);
    }

    public SelectItem[] getItemsAvailableSelectOne() {
        return JsfUtil.getSelectItems(ejbFacade.findAll(), true);
    }

    @FacesConverter(forClass = Grupoequipamento.class)
    public static class GrupoequipamentoControllerConverter implements Converter {

        public Object getAsObject(FacesContext facesContext, UIComponent component, String value) {
            if (value == null || value.length() == 0) {
                return null;
            }
            GrupoequipamentoController controller = (GrupoequipamentoController) facesContext.getApplication().getELResolver().
                    getValue(facesContext.getELContext(), null, "grupoequipamentoController");
            return controller.ejbFacade.find(getKey(value));
        }

        java.lang.Integer getKey(String value) {
            java.lang.Integer key;
            key = Integer.valueOf(value);
            return key;
        }

        String getStringKey(java.lang.Integer value) {
            StringBuffer sb = new StringBuffer();
            sb.append(value);
            return sb.toString();
        }

        public String getAsString(FacesContext facesContext, UIComponent component, Object object) {
            if (object == null) {
                return null;
            }
            if (object instanceof Grupoequipamento) {
                Grupoequipamento o = (Grupoequipamento) object;
                return getStringKey(o.getIdgrupoequipamento());
            } else {
                throw new IllegalArgumentException("object " + object + " is of type " + object.getClass().getName() + "; expected type: " + GrupoequipamentoController.class.getName());
            }
        }
    }
}

Facade Abstrata

public abstract class AbstractFacade<T> {
    private Class<T> entityClass;

    public AbstractFacade(Class<T> entityClass) {
        this.entityClass = entityClass;
    }

    protected abstract EntityManager getEntityManager();

    public void create(T entity) {
        getEntityManager().persist(entity);
    }

    public void edit(T entity) {
        getEntityManager().merge(entity);
    }

    public void remove(T entity) {
        getEntityManager().remove(getEntityManager().merge(entity));
    }

    public T find(Object id) {
        return getEntityManager().find(entityClass, id);
    }

    public List<T> findAll() {
        javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        cq.select(cq.from(entityClass));
        return getEntityManager().createQuery(cq).getResultList();
    }

    public List<T> findRange(int[] range) {
        javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        cq.select(cq.from(entityClass));
        javax.persistence.Query q = getEntityManager().createQuery(cq);
        q.setMaxResults(range[1] - range[0]);
        q.setFirstResult(range[0]);
        return q.getResultList();
    }

    public int count() {
        javax.persistence.criteria.CriteriaQuery cq = getEntityManager().getCriteriaBuilder().createQuery();
        javax.persistence.criteria.Root<T> rt = cq.from(entityClass);
        cq.select(getEntityManager().getCriteriaBuilder().count(rt));
        javax.persistence.Query q = getEntityManager().createQuery(cq);
        return ((Long) q.getSingleResult()).intValue();
    }
    
}

GrupoEquipamentoFacade

@Stateless
public class GrupoequipamentoFacade extends AbstractFacade<Grupoequipamento> {
    @PersistenceContext(unitName = "SACAWebPU")
    private EntityManager em;

    protected EntityManager getEntityManager() {
        return em;
    }

    public GrupoequipamentoFacade() {
        super(Grupoequipamento.class);
    }
    
}
FernandoFranzini

Vc ta usando o pefil JEE 6 para rodar só isso??

philipe

Sim! Foi por padrão! Nem mudei não!

FernandoFranzini

Ta explicado então…
Vc tem noção do tanto de serviço e recursos que glassfish colocou no ar e esta gastando memoria para executar só isso?

Criado 14 de setembro de 2011
Ultima resposta 15 de set. de 2011
Respostas 10
Participantes 4