E ae galera to fazendo um aplicação de cadastro simples, mas não está gravando em banco e não está gerando erro pra que eu possa ter noção do que está errado e corrigir para gravar em banco.
Para essa aplicação estou usando Primefaces,EclipseLink,Glassfish3.1,EJB e Postgresql, caso necessário eu posso compactar o projeto e enviar.
Segue o codigo fonte:
package negocio.Dao;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import negocio.entidade.Usuario;
@Stateless
public class UsuarioDao {
@PersistenceContext
private EntityManager em;
public void excluir(Usuario usuario) {
Usuario usuarioASerExcluido = em.merge(usuario);
em.remove(usuarioASerExcluido);
}
public void alterar(Usuario usuario) {
em.merge(usuario);
}
public void inserir(Usuario usuario) {
em.persist(usuario);
}
public List<Usuario> recuperarTodos() {
return em.createQuery("select age from Usuario as age order by age.nome").getResultList();
}
}
package negocio.entidade;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
@Entity
@Table(name = "usuario")
@Inheritance(strategy=InheritanceType.SINGLE_TABLE)
@NamedQueries({
@NamedQuery(name = "Usuario.findAll", query = "SELECT u FROM Usuario u"),
@NamedQuery(name = "Usuario.findByUsuarioId", query = "SELECT u FROM Usuario u WHERE u.usuarioId = :usuarioId"),
@NamedQuery(name = "Usuario.findByNome", query = "SELECT u FROM Usuario u WHERE u.nome = :nome"),
@NamedQuery(name = "Usuario.findBySobrenome", query = "SELECT u FROM Usuario u WHERE u.sobrenome = :sobrenome"),
@NamedQuery(name = "Usuario.findBySexo", query = "SELECT u FROM Usuario u WHERE u.sexo = :sexo"),
@NamedQuery(name = "Usuario.findByDtnascim", query = "SELECT u FROM Usuario u WHERE u.dtnascim = :dtnascim"),
@NamedQuery(name = "Usuario.findByEmail", query = "SELECT u FROM Usuario u WHERE u.email = :email"),
@NamedQuery(name = "Usuario.findByEmailalt", query = "SELECT u FROM Usuario u WHERE u.emailalt = :emailalt"),
@NamedQuery(name = "Usuario.findByTelefone", query = "SELECT u FROM Usuario u WHERE u.telefone = :telefone"),
@NamedQuery(name = "Usuario.findByRua", query = "SELECT u FROM Usuario u WHERE u.rua = :rua"),
@NamedQuery(name = "Usuario.findByCep", query = "SELECT u FROM Usuario u WHERE u.cep = :cep"),
@NamedQuery(name = "Usuario.findByCidade", query = "SELECT u FROM Usuario u WHERE u.cidade = :cidade"),
@NamedQuery(name = "Usuario.findByEstado", query = "SELECT u FROM Usuario u WHERE u.estado = :estado"),
@NamedQuery(name = "Usuario.findByPais", query = "SELECT u FROM Usuario u WHERE u.pais = :pais"),
@NamedQuery(name = "Usuario.findByStatus", query = "SELECT u FROM Usuario u WHERE u.status = :status")})
public abstract class Usuario implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@SequenceGenerator(name="Usuario_Generator", sequenceName="usuario_sequence", allocationSize=1)
@GeneratedValue(strategy=GenerationType.SEQUENCE, generator="Usuario_Generator")
@Column(name = "usuario_id")
private Integer usuarioId;
@Column(name = "nome", nullable = false)
private String nome;
@Column(name = "sobrenome", nullable = false)
private String sobrenome;
@Column(name = "sexo", nullable = false)
private String sexo;
@Column(name = "dtnascim", nullable = false)
private String dtnascim;
@Column(name = "email", nullable = false)
private String email;
@Column(name = "emailalt", nullable = false)
private String emailalt;
@Column(name = "telefone", nullable = false)
private String telefone;
@Column(name = "rua", nullable = false)
private String rua;
@Column(name = "cep", nullable = false)
private String cep;
@Column(name = "cidade", nullable = false)
private String cidade;
@Column(name = "estado", nullable = false)
private String estado;
@Column(name = "pais", nullable = false)
private String pais;
@Column(name = "status", nullable = true)
private String status;
public Usuario() {
}
public Usuario(Integer usuarioId) {
this.usuarioId = usuarioId;
}
public Usuario(Integer usuarioId, String nome, String sobrenome, String sexo, String dtnascim, String email, String emailalt, String telefone, String rua, String cep, String cidade, String estado, String pais, String status) {
this.usuarioId = usuarioId;
this.nome = nome;
this.sobrenome = sobrenome;
this.sexo = sexo;
this.dtnascim = dtnascim;
this.email = email;
this.emailalt = emailalt;
this.telefone = telefone;
this.rua = rua;
this.cep = cep;
this.cidade = cidade;
this.estado = estado;
this.pais = pais;
this.status = status;
}
public Integer getUsuarioId() {
return usuarioId;
}
public void setUsuarioId(Integer usuarioId) {
this.usuarioId = usuarioId;
}
public String getNome() {
return nome;
}
public void setNome(String nome) {
this.nome = nome;
}
public String getSobrenome() {
return sobrenome;
}
public void setSobrenome(String sobrenome) {
this.sobrenome = sobrenome;
}
public String getSexo() {
return sexo;
}
public void setSexo(String sexo) {
this.sexo = sexo;
}
public String getDtnascim() {
return dtnascim;
}
public void setDtnascim(String dtnascim) {
this.dtnascim = dtnascim;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getEmailalt() {
return emailalt;
}
public void setEmailalt(String emailalt) {
this.emailalt = emailalt;
}
public String getTelefone() {
return telefone;
}
public void setTelefone(String telefone) {
this.telefone = telefone;
}
public String getRua() {
return rua;
}
public void setRua(String rua) {
this.rua = rua;
}
public String getCep() {
return cep;
}
public void setCep(String cep) {
this.cep = cep;
}
public String getCidade() {
return cidade;
}
public void setCidade(String cidade) {
this.cidade = cidade;
}
public String getEstado() {
return estado;
}
public void setEstado(String estado) {
this.estado = estado;
}
public String getPais() {
return pais;
}
public void setPais(String pais) {
this.pais = pais;
}
public String getStatus() {
return status;
}
public void setStatus(String status) {
this.status = status;
}
@Override
public int hashCode() {
int hash = 0;
hash += (usuarioId != null ? usuarioId.hashCode() : 0);
return hash;
}
@Override
public boolean equals(Object object) {
// TODO: Warning - this method won't work in the case the id fields are not set
if (!(object instanceof Usuario)) {
return false;
}
Usuario other = (Usuario) object;
if ((this.usuarioId == null && other.usuarioId != null) || (this.usuarioId != null && !this.usuarioId.equals(other.usuarioId))) {
return false;
}
return true;
}
@Override
public String toString() {
return "negocio.entidade.Usuario[ usuarioId=" + usuarioId + " ]";
}
}
package negocio.fachada;
import java.util.List;
import javax.ejb.EJB;
import javax.ejb.Stateless;
import negocio.entidade.Usuario;
import negocio.Dao.UsuarioDao;
@Stateless
public class UsuarioFachada {
@EJB
private UsuarioDao usuarioDAO;
public void excluir(Usuario usuario){
usuarioDAO.excluir(usuario);
}
public void inserir(Usuario usuario) {
usuarioDAO.inserir(usuario);
}
public List<Usuario> listar(){
return usuarioDAO.recuperarTodos();
}
}
package negocio.managedbean;
import javax.ejb.EJB;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.model.ListDataModel;
import negocio.entidade.Usuario;
import negocio.fachada.UsuarioFachada;
@ManagedBean(name = "agenciaManagedBean")
@SessionScoped
public class UsuarioMB {
private Usuario usuario;
private ListDataModel usuarios;
@EJB
private UsuarioFachada usuarioFachada;
public UsuarioMB(){}
public Usuario getUsuario() {
return usuario;
}
public void setUsuario(Usuario usuario) {
this.usuario = usuario;
}
public ListDataModel getUsuarios() {
return usuarios;
}
public String excluir() {
usuarioFachada.excluir(this.getUsuario());
this.recuperarUsuarios();
return "/usuario/ListarUsuarios";
}
public String listar() {
this.recuperarUsuarios();
return "/usuario/ListarUsuarios";
}
public String inserir() {
usuarioFachada.inserir(this.getUsuario());
this.recuperarUsuarios();
return "/usuario/ListarUsuarios";
}
private void recuperarUsuario() {
this.usuario = (Usuario) this.usuarios.getRowData();
}
private void recuperarUsuarios() {
this.usuarios = new ListDataModel(usuarioFachada.listar());
}
}