Estou com problemas ao tentar alterar um objeto que tem relacionamento com outros objetos, meu código está assim:
package com.modelo.managedBean;
import com.modelo.bean.Promotor;
import com.modelo.dao.PromotorDAO;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class PromotorMB implements Serializable {
private Integer id;
private PromotorDAO promotorDAO;
private Promotor promotor = new Promotor();
private List<Promotor> promotores = new ArrayList<Promotor>();
// GETTER / SETTER
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
if (id != null) {
promotor = promotorDAO.recuperarPromotor(this.getId());
}
}
public Promotor getPromotor() {
return promotor;
}
public void setPromotor(Promotor promotor) {
this.promotor = promotor;
}
public List<Promotor> getPromotores() {
promotorDAO = new PromotorDAO();
promotores = promotorDAO.listarPromotores();
return promotores;
}
// REGRAS DE NEGÓCIO
public String salvar() {
promotor.getGrupoAcesso().setLogin(promotor.getLogin());
if (promotorDAO.inserirPromotor(promotor)) {
return "sucessoOperacao";
} else {
return "falhaOperacao";
}
}
public String excluir() {
promotor = promotorDAO.recuperarPromotor(promotor.getIdUsuario());
if (promotorDAO.excluirPromotor(promotor)) {
return "sucessoOperacao";
} else {
return "falhaOperacao";
}
}
public String atualizar() {
//promotor.getGrupoAcesso().setLogin(promotor.getLogin());
promotorDAO = new PromotorDAO();
if (promotorDAO.atualizarPromotor(promotor)) {
return "sucessoOperacao";
} else {
return "falhaOperacao";
}
}
}
Eu listo todos os registros daquele tipo na tela, escolho qual eu desejo alterar e passo ele pra outra tela de edição, quando passo ele pra tela de edição carrego o managedBean referente ao objeto, eu debuguei e ele está vindo blz, está puxando todos os objetos relacionados. Porém quando vou dar o merge no BD ocorre este erro:
Advertência: #{promotorMB.atualizar}: java.lang.IllegalStateException: Transaction not active
javax.faces.FacesException: #{promotorMB.atualizar}: java.lang.IllegalStateException: Transaction not active
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:118)
at javax.faces.component.UICommand.broadcast(UICommand.java:315)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:593)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:563)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:722)
Caused by: javax.faces.el.EvaluationException: java.lang.IllegalStateException: Transaction not active
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:102)
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102)
... 23 more
Caused by: java.lang.IllegalStateException: Transaction not active
at org.hibernate.ejb.TransactionImpl.rollback(TransactionImpl.java:82)
at com.modelo.dao.PromotorDAO.atualizarPromotor(PromotorDAO.java:58)
at com.modelo.managedBean.PromotorMB.atualizar(PromotorMB.java:68)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.apache.el.parser.AstValue.invoke(AstValue.java:191)
at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:276)
at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:88)
... 24 more
código da persistencia:
package com.modelo.dao;
import com.modelo.bean.Promotor;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;
import javax.persistence.Query;
public class PromotorDAO {
private EntityManagerFactory factory = null;
private EntityManager manager = null;
public PromotorDAO() {
factory = Persistence.createEntityManagerFactory("TurismoGuiadoPU");
manager = factory.createEntityManager();
}
public boolean inserirPromotor(Promotor promotor) {
try {
manager.getTransaction().begin();
manager.persist(promotor);
manager.getTransaction().commit();
return true;
} catch (Exception e) {
manager.getTransaction().rollback();
System.err.println("Erro: " + e.getMessage());
return false;
} finally {
manager.close();
}
}
public boolean excluirPromotor(Promotor promotor) {
try {
manager.getTransaction().begin();
manager.remove(promotor);
manager.getTransaction().commit();
return true;
} catch (Exception e) {
manager.getTransaction().rollback();
System.err.println("Erro: " + e.getMessage());
return false;
} finally {
manager.close();
}
}
public boolean atualizarPromotor(Promotor promotor) {
try {
manager.getTransaction().begin();
manager.merge(promotor);
manager.getTransaction().commit();
return true;
} catch (Exception e) {
manager.getTransaction().rollback();
System.err.println("Erro: " + e.getMessage());
return false;
} finally {
manager.close();
}
}
public Promotor recuperarPromotor(int idPromotor) {
Promotor promotor = manager.find(Promotor.class, idPromotor);
return promotor;
}
public List<Promotor> listarPromotores() {
EntityTransaction transaction = manager.getTransaction();
Query query = manager.createQuery("SELECT a FROM Promotor a");
List<Promotor> promotores = query.getResultList();
return promotores;
}
}