Diferencia entre revisiones de «Practicas con Hibernate»

De Dos Ideas.
Saltar a: navegación, buscar
(Entidades)
(Uno a Uno)
Línea 64: Línea 64:
 
             name="cuerpoId", unique=true, nullable=false, updatable=false)
 
             name="cuerpoId", unique=true, nullable=false, updatable=false)
 
     private Cuerpo cuerpo;
 
     private Cuerpo cuerpo;
 +
</code>
 +
 +
==== DAO ====
 +
'''CuerpoDao'''
 +
<code java>
 +
@Repository
 +
@Transactional
 +
public class CuerpoDaoImpl implements CuerpoDao {
 +
 +
    @Autowired
 +
    private SessionFactory sessionFactory;
 +
   
 +
    public Cuerpo buscarPorId(Long id) {
 +
        return (Cuerpo) sessionFactory.getCurrentSession().get(Cuerpo.class, id);
 +
    }
 +
 +
    public void guardar(Cuerpo cuerpo) {
 +
        sessionFactory.getCurrentSession().save(cuerpo);           
 +
    }
 +
 +
    public void eliminar(Cuerpo cuerpo) {
 +
        sessionFactory.getCurrentSession().delete(cuerpo);
 +
    }
 +
 +
}
 
</code>
 
</code>
  

Revisión del 12:43 15 mar 2012

En este apartado mostraremos diferentes ejemplos de uso de hibernate, usando de prueba un proyecto con hibernate más spring

Cardinalidad entre entidades

Uno a Uno

Entidades

Ej.: Un cuerpo esta compuesto por un corazón

Cuerpo @Entity @Table(name = "Cuerpo", schema = "UnoAUno") public class Cuerpo {

   @Id
   @GeneratedValue(strategy = GenerationType.IDENTITY)
   @Column(name = "cuerpoId")
   private Long id;
   @Column(name = "cuerpoDescripcion")
   private String descripcion;
   
   @OneToOne(mappedBy = "cuerpo", cascade = CascadeType.ALL)
   private Corazon corazon;
  
   //Getter and Setter
   ...

}

Con la siguiente anotación decimos que el cuerpo posee una relación con la entidad corazón; y en la entidad corazón la relación esta dado por el atributo cuerpo. @OneToOne(mappedBy = "cuerpo", cascade = CascadeType.ALL) private Corazon corazon;

Corazón @Entity @Table(name = "Corazon", schema = "UnoAUno") public class Corazon {

   @Id
   @GeneratedValue(strategy = GenerationType.IDENTITY)
   @Column(name = "corazonId")
   private Long id;
   @OneToOne(optional=false)
   @JoinColumn(
           name="cuerpoId", unique=true, nullable=false, updatable=false)
   private Cuerpo cuerpo;
   @Column(name = "corazonDescripcion")
   private String descripcion;
   //Getter and Setter
   ...

} Con la siguiente anotación decimos que el corazon esta relacionado uno a uno con el cuerpo y la existencia de este último es obligatoria (optional=false). Además, en caso de que este relacionado por una FK, definimos que el Join, lo realice utilizando la FK.

   @OneToOne(optional=false)
   @JoinColumn(
           name="cuerpoId", unique=true, nullable=false, updatable=false)
   private Cuerpo cuerpo;

DAO

CuerpoDao @Repository @Transactional public class CuerpoDaoImpl implements CuerpoDao {

   @Autowired
   private SessionFactory sessionFactory;
   
   public Cuerpo buscarPorId(Long id) {
       return (Cuerpo) sessionFactory.getCurrentSession().get(Cuerpo.class, id);
   }
   public void guardar(Cuerpo cuerpo) {
       sessionFactory.getCurrentSession().save(cuerpo);            
   }
   public void eliminar(Cuerpo cuerpo) {
       sessionFactory.getCurrentSession().delete(cuerpo);
   }

}

Ver también