Introducción
La asociación One To One en Hibernate es uno de los tipos de asociaciones entre entidades que representan una relación uno a uno entre dos tablas en una base de datos.
Es decir, un registro en la tabla A se relaciona con un solo registro en la tabla B y viceversa.
Configuración en Hibernate
La asociación One To One puede ser unidireccional o bidireccional.
Asociación unidireccional
Supóngase que se tienen dos entidades: Persona
y LicenciaConducir
.
import jakarta.persistence.*;
@Entity
public class Persona {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String nombre;
@OneToOne
@JoinColumn(name = "licencia_id")
private LicenciaConducir licenciaConducir;
// getters y setters
}
import jakarta.persistence.*;
@Entity
public class LicenciaConducir {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String numeroLicencia;
// getters y setters
}
La anotación @OneToOne
indica que se trata de una relación uno a uno. @JoinColumn
especifica qué columna se debe usar como clave foránea. En este caso, la tabla Persona
tendrá una columna licencia_id
que será una clave foránea que hace referencia a la tabla LicenciaConducir
.
Asociación bidireccional
El atributo mappedBy
es crucial cuando se trata de relaciones bidireccionales en Hibernate. Sirve para definir el "lado no propietario" de la relación. Es decir, indica cuál de las dos entidades involucradas en una relación bidireccional es la que no controla directamente la asociación en la base de datos, pero aún necesita estar al tanto de ella.
Lado Propietario y Lado No Propietario: En una relación bidireccional, siempre hay un "lado propietario" y un "lado no propietario". El lado propietario es el que se encarga de actualizar la relación en la base de datos. Hibernate sólo considera la configuración del lado propietario cuando detecta cambios en la relación.
No se usa una columna extra: Cuando se usa mappedBy
, Hibernate sabe que no tiene que crear una columna adicional en la base de datos para esa relación. Si no se usa, Hibernate podría tratar de crear dos columnas de clave foránea en ambas tablas, lo que no es correcto en una relación One-To-One.
Valor de mappedBy
: El valor que se asigna al atributo mappedBy
es el nombre del atributo en la entidad propietaria que mantiene la relación. No es el nombre de la columna en la base de datos.
Siguiendo el ejemplo anterior de Persona
y LicenciaConducir
:
import jakarta.persistence.*;
@Entity
public class Persona {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String nombre;
@OneToOne
@JoinColumn(name = "licencia_id")
private LicenciaConducir licenciaConducir;
// getters y setters
}
import jakarta.persistence.*;
@Entity
public class LicenciaConducir {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String numeroLicencia;
@OneToOne(mappedBy = "licenciaConducir")
private Persona persona;
// getters y setters
}
Aquí, la entidad Persona
es el lado propietario de la relación, porque tiene la anotación @JoinColumn
. Esto significa que es responsable de gestionar la clave foránea (licencia_id
) en la base de datos.
Por otro lado, LicenciaConducir
tiene el atributo mappedBy
con el valor "licenciaConducir", lo que indica que es el lado no propietario y que debe mirar el atributo licenciaConducir
en la entidad Persona
para entender la relación.
Fuentes y referencias
Documentación oficial y recursos externos para profundizar en Hibernate
Documentación oficial de Hibernate
Alan Sastre
Ingeniero de Software y formador, CEO en CertiDevs
Ingeniero de software especializado en Full Stack y en Inteligencia Artificial. Como CEO de CertiDevs, Hibernate es una de sus áreas de expertise. Con más de 15 años programando, 6K seguidores en LinkedIn y experiencia como formador, Alan se dedica a crear contenido educativo de calidad para desarrolladores de todos los niveles.
Más tutoriales de Hibernate
Explora más contenido relacionado con Hibernate y continúa aprendiendo con nuestros tutoriales gratuitos.
Aprendizajes de esta lección
- Comprender el concepto de la asociación One To One en Hibernate y cómo representa una relación uno a uno entre entidades.
- Aprender a configurar una asociación One To One unidireccional mediante anotaciones como
@OneToOne
y@JoinColumn
. - Conocer la diferencia entre el "lado propietario" y el "lado no propietario" en una relación bidireccional.
- Entender la importancia del atributo
mappedBy
en una relación bidireccional y cómo se utiliza para definir el lado no propietario de la relación. - Reconocer que en una relación One To One bidireccional, el atributo
mappedBy
evita la creación de una columna adicional en la base de datos y establece la referencia entre las entidades.
Cursos que incluyen esta lección
Esta lección forma parte de los siguientes cursos estructurados con rutas de aprendizaje