javax.persistence.MapKeyEnumerated Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jakarta.persistence Show documentation
Show all versions of jakarta.persistence Show documentation
jakarta.persistence build based upon git transaction 3194cec
The newest version!
/*
* Copyright (c) 2008, 2019 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/
// Contributors:
// Linda DeMichiel - 2.1
// Linda DeMichiel - 2.0
package javax.persistence;
import java.lang.annotation.Target;
import java.lang.annotation.Retention;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import static javax.persistence.EnumType.ORDINAL;
/**
* Specifies the enum type for a map key whose basic type is an enumerated type.
*
* The MapKeyEnumerated
annotation can be applied to an
* element collection or relationship of type java.util.Map
, in
* conjunction with the ElementCollection
, OneToMany
, or
* ManyToMany
annotation.
* If the enumerated type is not specified or the MapKeyEnumerated
* annotation is not used, the enumerated type is assumed to be
* ORDINAL
.
*
*
* Example:
*
* public enum ProjectStatus {COMPLETE, DELAYED, CANCELLED, IN_PROGRESS}
*
* public enum SalaryRate {JUNIOR, SENIOR, MANAGER, EXECUTIVE}
*
* @Entity public class Employee {
* @ManyToMany
* public Projects<ProjectStatus, Project> getProjects() {...}
*
* @OneToMany
* @MapKeyEnumerated(STRING)
* public Map<SalaryRate, Employee> getEmployees() {...}
* ...
* }
*
*
* @see ElementCollection
* @see OneToMany
* @see ManyToMany
*
* @since 2.0
*/
@Target({METHOD, FIELD}) @Retention(RUNTIME)
public @interface MapKeyEnumerated {
/** (Optional) The type used in mapping a map key enum type. */
EnumType value() default ORDINAL;
}