Asociación One To One

Intermedio
Hibernate
Hibernate
Hoy: 21/10/2025

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 - Autor del tutorial

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

  1. Comprender el concepto de la asociación One To One en Hibernate y cómo representa una relación uno a uno entre entidades.
  2. Aprender a configurar una asociación One To One unidireccional mediante anotaciones como @OneToOne y @JoinColumn.
  3. Conocer la diferencia entre el "lado propietario" y el "lado no propietario" en una relación bidireccional.
  4. 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.
  5. 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