1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Mapeamento Hibernate

Galera, é o seguinte, fiz um relacionamento com o hibernate de 1-1, e corrigi outros erros que apareceram, porém está acontecendo uma coisa estranha, ele insere os dados certinho no banco, mas o fk fica null.

Modelo Cliente

@Entity
public class Cliente {

    @Id 
    @GeneratedValue
    private Long id;
    private boolean juridica;
    private String nomeOuRazaoSocial;
    private String nomeFantasia;
    private String cpfOuCnpj;
    private String rgOuInscricaoEstadual;

    @Temporal(TemporalType.DATE)
    private Calendar dataNacimentoOuCriacaoEmpresa;

    @Temporal(TemporalType.DATE)
    private Calendar dataAdesao;

    private Double limite;
    private Double saldo;

    @OneToOne(mappedBy = "cliente", targetEntity = Endereco.class, fetch = FetchType.LAZY, cascade = javax.persistence.CascadeType.ALL)  
    private Endereco endereco;

//geters e setters
}

Modelo Endereco

@Entity
public class Endereco {

    @Id
    @GeneratedValue
    private Long id;
    private String rua;
    private String numero;
    private String complemento;
    private String bairro;
    private String cidade;
    private String estado;
    private String cep;
    private String pontoReferencia;

    @OneToOne
    @JoinColumn(name="cliente_id")
    private Cliente cliente;

//geters e setters
}

Hibernat.cfg.xml

<hibernate-configuration>
  <session-factory>
    <property name="hibernate.connection.username">
      root
    </property>
    <property name="hibernate.connection.password">
    </property>
    <property name="hibernate.connection.url">
      jdbc:mysql://localhost/xxx
    </property>
    <property name="hibernate.connection.driver_class">
      com.mysql.jdbc.Driver
    </property>
    <property name="hibernate.dialect">
      org.hibernate.dialect.MySQL5InnoDBDialect
    </property>

    <property name="hibernate.hbm2ddl.auto">update</property>

    <property name="show_sql">true</property>
    <property name="format_sql">true</property>

    <!-- entidades -->
    <mapping class="br.com.xxx.model.Endereco" />
    <mapping class="br.com.xxx.model.Cliente" />
    <mapping class="br.com.xxx.model.DadosBancarios" />

  </session-factory>
</hibernate-configuration>

Alguém poderia me ajudar que ainda não consegui encontrar o porque?

Alguém sabe?

Editado

Consegui galera, mas achei a solução estranha...

pra resolver o que fiz:

cliente.setEndereco(endereco);
endereco.setCliente(cliente);

Aí ele grava a chave estrangeira...

Isso tá certo?

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags hibernate persistência banco-de-dados ou faça a sua própria pergunta.