SelectOneMenu - JSF + Hibernate

0 respostas
Ramon.Onix

PessoAll, tô com um probleminha, mas não consigo resolver.
As anotações foram feitas pelo Netbeans, é um projeto final de faculdade e tô perdido.

tenho uma classe Endereço

@Entity
@Table(name = "endereco")
@XmlRootElement
@NamedQueries({
    @NamedQuery(name = "Endereco.findAll", query = "SELECT e FROM Endereco e"),
    @NamedQuery(name = "Endereco.findByIdEndereco", query = "SELECT e FROM Endereco e WHERE e.idEndereco = :idEndereco"),
    @NamedQuery(name = "Endereco.findByLogradouroEndereco", query = "SELECT e FROM Endereco e WHERE e.logradouroEndereco = :logradouroEndereco"),
    @NamedQuery(name = "Endereco.findByComplementoEndereco", query = "SELECT e FROM Endereco e WHERE e.complementoEndereco = :complementoEndereco"),
    @NamedQuery(name = "Endereco.findByBairroEndereco", query = "SELECT e FROM Endereco e WHERE e.bairroEndereco = :bairroEndereco"),
    @NamedQuery(name = "Endereco.findByCepEndereco", query = "SELECT e FROM Endereco e WHERE e.cepEndereco = :cepEndereco"),
    @NamedQuery(name = "Endereco.findByMunicipioEndereco", query = "SELECT e FROM Endereco e WHERE e.municipioEndereco = :municipioEndereco")})
public class Endereco implements Serializable {
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "enderecoIdEndereco")
    private Collection<Pessoa> pessoaCollection;
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Basic(optional = false)
    @NotNull
    @Column(name = "id_endereco")
    private Integer idEndereco;
    @Size(max = 200)
    @Column(name = "logradouro_endereco")
    private String logradouroEndereco;
    @Size(max = 200)
    @Column(name = "complemento_endereco")
    private String complementoEndereco;
    @Size(max = 200)
    @Column(name = "bairro_endereco")
    private String bairroEndereco;
    @Column(name = "cep_endereco")
    private Integer cepEndereco;
    @Size(max = 200)
    @Column(name = "municipio_endereco")
    private String municipioEndereco;
    @JoinColumn(name = "municipio_id_municipio", referencedColumnName = "id_municipio")
    @ManyToOne(optional = false)
    private Municipio municipioIdMunicipio;

    public Endereco() {
    }

    public Endereco(Integer idEndereco) {
        this.idEndereco = idEndereco;
    }

    public Integer getIdEndereco() {
        return idEndereco;
    }

    public void setIdEndereco(Integer idEndereco) {
        this.idEndereco = idEndereco;
    }

    public String getLogradouroEndereco() {
        return logradouroEndereco;
    }

    public void setLogradouroEndereco(String logradouroEndereco) {
        this.logradouroEndereco = logradouroEndereco;
    }

    public String getComplementoEndereco() {
        return complementoEndereco;
    }

    public void setComplementoEndereco(String complementoEndereco) {
        this.complementoEndereco = complementoEndereco;
    }

    public String getBairroEndereco() {
        return bairroEndereco;
    }

    public void setBairroEndereco(String bairroEndereco) {
        this.bairroEndereco = bairroEndereco;
    }

    public Integer getCepEndereco() {
        return cepEndereco;
    }

    public void setCepEndereco(Integer cepEndereco) {
        this.cepEndereco = cepEndereco;
    }

    public String getMunicipioEndereco() {
        return municipioEndereco;
    }

    public void setMunicipioEndereco(String municipioEndereco) {
        this.municipioEndereco = municipioEndereco;
    }

    public Municipio getMunicipioIdMunicipio() {
        return municipioIdMunicipio;
    }

    public void setMunicipioIdMunicipio(Municipio municipioIdMunicipio) {
        this.municipioIdMunicipio = municipioIdMunicipio;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (idEndereco != null ? idEndereco.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 Endereco)) {
            return false;
        }
        Endereco other = (Endereco) object;
        if ((this.idEndereco == null && other.idEndereco != null) || (this.idEndereco != null && !this.idEndereco.equals(other.idEndereco))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "modelo.Endereco[ idEndereco=" + idEndereco + " ]";
    }

    @XmlTransient
    public Collection<Pessoa> getPessoaCollection() {
        return pessoaCollection;
    }

    public void setPessoaCollection(Collection<Pessoa> pessoaCollection) {
        this.pessoaCollection = pessoaCollection;
    }
    
}

e outra Municipio

@Entity
@Table(name = "municipio")
@XmlRootElement
@NamedQueries({
    @NamedQuery(name = "Municipio.findAll", query = "SELECT m FROM Municipio m"),
    @NamedQuery(name = "Municipio.findByIdMunicipio", query = "SELECT m FROM Municipio m WHERE m.idMunicipio = :idMunicipio"),
    @NamedQuery(name = "Municipio.findByNomeMunicipio", query = "SELECT m FROM Municipio m WHERE m.nomeMunicipio = :nomeMunicipio"),
    @NamedQuery(name = "Municipio.findByUfMunicipio", query = "SELECT m FROM Municipio m WHERE m.ufMunicipio = :ufMunicipio"),
    @NamedQuery(name = "Municipio.findByPaisMunicipio", query = "SELECT m FROM Municipio m WHERE m.paisMunicipio = :paisMunicipio")})
public class Municipio implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Basic(optional = false)
    @NotNull
    @Column(name = "id_municipio")
    private Integer idMunicipio;
    @Size(max = 200)
    @Column(name = "nome_municipio")
    private String nomeMunicipio;
    @Size(max = 200)
    @Column(name = "uf_municipio")
    private String ufMunicipio;
    @Size(max = 200)
    @Column(name = "pais_municipio")
    private String paisMunicipio;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "municipioIdMunicipio")
    private Collection<Endereco> enderecoCollection;

    public Municipio() {
    }

    public Municipio(Integer idMunicipio) {
        this.idMunicipio = idMunicipio;
    }

    public Integer getIdMunicipio() {
        return idMunicipio;
    }

    public void setIdMunicipio(Integer idMunicipio) {
        this.idMunicipio = idMunicipio;
    }

    public String getNomeMunicipio() {
        return nomeMunicipio;
    }

    public void setNomeMunicipio(String nomeMunicipio) {
        this.nomeMunicipio = nomeMunicipio;
    }

    public String getUfMunicipio() {
        return ufMunicipio;
    }

    public void setUfMunicipio(String ufMunicipio) {
        this.ufMunicipio = ufMunicipio;
    }

    public String getPaisMunicipio() {
        return paisMunicipio;
    }

    public void setPaisMunicipio(String paisMunicipio) {
        this.paisMunicipio = paisMunicipio;
    }

    @XmlTransient
    public Collection<Endereco> getEnderecoCollection() {
        return enderecoCollection;
    }

    public void setEnderecoCollection(Collection<Endereco> enderecoCollection) {
        this.enderecoCollection = enderecoCollection;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (idMunicipio != null ? idMunicipio.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 Municipio)) {
            return false;
        }
        Municipio other = (Municipio) object;
        if ((this.idMunicipio == null && other.idMunicipio != null) || (this.idMunicipio != null && !this.idMunicipio.equals(other.idMunicipio))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "modelo.Municipio[ idMunicipio=" + idMunicipio + " ]";
    }
    
}

Ai vc viram que tem o relacionamento, o municipio é facil gravar, mas o endereço ta me tirando do sério.

Tenho um SelectOne menu que é montado com os valores advindos do banco.

<h:selectOneMenu converter="municipioConverter" value="#{enderecoController.endereco.municipioIdMunicipio}">
<f:selectItem itemValue="0" itemLabel="Selecione..."/>
<f:selectItems var="lm" value="#{enderecoController.listarMunicipios}" itemValue="#{lm.idMunicipio}" itemLabel="#{lm.nomeMunicipio}"/>
</h:selectOneMenu>

//Monta os dados do combo

public List<SelectItem> getListarMunicipios() {
        List<Municipio> municipios = new MunicipioHib().listarMunicipios();
        List<SelectItem> itens = new ArrayList<SelectItem>(municipios.size());
        for (Municipio m : municipios) {
            //itens.add(new SelectItem(m.getIdMunicipio().toString(), m.getNomeMunicipio()));
            itens.add(new SelectItem(m, m.getNomeMunicipio()));
        }
        return itens;
}

//Converter
@FacesConverter(value = "municipioConverter", forClass = Municipio.class)
public class MunicipioConverter implements Converter {

    @Override
    public Object getAsObject(FacesContext arg0, UIComponent arg1, String id) {
        if (id == null || id.isEmpty()) {
            return null;
        }
        System.out.println("arg 0 - "+arg0);
        System.out.println("arg 1 - "+arg1);
        System.out.println("id - "+id);
        Municipio municipio = new Municipio();
        return new MunicipioHib().buscarMunicipioId(municipio.getIdMunicipio());
    }

    @Override
    public String getAsString(FacesContext arg0, UIComponent arg1, Object value) {
        if (value == null || value.toString().isEmpty()) {
            return "0";
        }
        System.out.println("arg 0 - "+arg0);
        System.out.println("arg 1 - "+arg1);
        System.out.println("value - "+value);
        //Municipio municipios = (Municipio)value;
        //return municipios.getIdMunicipio().toString();
        return value.toString();
    }
}

a combo funciona perfeitamente, só não consigo gravar.
Não sei se o erro é no converter.

Erro:

Criado 8 de maio de 2012
Respostas 0
Participantes 1