Una de las ventajas de utilizar enumeraciones en Java, es podemos limitar los valores posibles para una propiedad, forzando a los desarrolladores a utilizar los valores ya definidos y evitando el margen de error.
@Enumerated
Con JPA también es posible utilizar enumeraciones y pueden ser de mucha ayuda para asegurar que los programadores persistan un valor válido dentro de una lista previamente definida. JPA nos permite mediante la anotación @Enumerated definir la forma en que una enumeración será persistida, las cuales se explican a continuación:
- String: permite persistir la enumeración por su nombre, lo que significa que será una columna alfanumérica. La anotación quedaría así:
- @Enumerated(value = EnumType.STRING)
- Ordinal: esta estrategia persiste un valor entero que corresponde al valor ordinal o posición de valor en la enumeración. La anotación quedaría de la siguiente manera:
- @Enumerated(value = EnumType.ORDINAL)
Retomaremos la entidad Employee que hemos venido analizando en todo este tutorial y le agregaremos una nueva propiedad que corresponda al status:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | package com.obb.jpa.jpaturorial.entity; import java.util.Calendar; import java.util.Objects; import javax.persistence.*; /** * @author Oscar Blancarte */ @Entity @Table( name = "EMPLOYEES" , schema = "jpatutorial", indexes = {@Index(name = "name_index", columnList = "name",unique = true)} ) public class Employee { @Id @GeneratedValue(strategy = GenerationType.IDENTITY, generator = "EmployeeTable") @Column(name = "ID") private Long id; @Column(name = "NAME", nullable = false, length = 150) private String name; @Column(name = "SALARY", nullable = false, scale = 2) private double salary; @Column(name = "REGIST_DATE", updatable = false, nullable = false) @Temporal(TemporalType.DATE) private Calendar registDate; @Column(name="status", nullable = false, length = 8 ) @Enumerated(value = EnumType.STRING) private Status status; /** * GETs and SETs */ } |
Veamos que la propiedad es de tipo Status, la cual es una enumeración y tiene definida la estrategia String. También podemos ver que está definida la anotación @Column para definir las características de la columna.
Por otra parte, tenemos la enumeración Status la cual tiene los posibles valores ACTIVE e INACTIVE.
1 2 3 4 5 6 7 8 9 | package com.obb.jpa.jpaturorial.entity; /** * @author Oscar Blancarte */ public enum Status { ACTIVE, INACTIVE } |
La anotación @Enumerated no es mandataria, pero el hecho de omitirla provocara que JPA determine la estrategia por default, que en nuestro caso sería Ordinal. Por eso yo siempre aconsejo definirla para no tener sorpresas.
Si ejecutamos nuestro el programa para que cree las tablas por nosotros veremos que se creara una columna de tipo VARCHAR ya que definimos String como estrategia. Por otro lado, si utilizamos Ordinal se creará una columna de tipo INT.
Yo siempre recomiendo utilizar Enumeraciones cuando definamos atributos que requieren valores fijos y previamente determinados, como una lista de valores, pero que esta lista no requiera cambiar en tiempo de ejecución. Una mala opción para utilizarla es para definir listas de valores que en el futuro requieran ampliarse sin necesidad de recompilar.
NOTA: Este artículo es solo una sección del Tutorial de JPA, para ver el contenido completo de este tutorial regresa al Índice en el botón de abajo.