/*
* Copyright (c) 2008, 2009, 2011 Oracle, Inc. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution. The Eclipse Public License is available
* at http://www.eclipse.org/legal/epl-v10.html and the Eclipse Distribution License
* is available at http://www.eclipse.org/org/documents/edl-v10.php.
*/
package javax.persistence;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
Specifies that a unique constraint is to be included in
the generated DDL for a primary or secondary table.
Example:
@Entity
@Table(
name="EMPLOYEE",
uniqueConstraints=
@UniqueConstraint(columnNames={"EMP_ID", "EMP_NAME"})
)
public class Employee { ... }
Since: Java Persistence 1.0
/**
* Specifies that a unique constraint is to be included in
* the generated DDL for a primary or secondary table.
* <p>
* <pre>
* Example:
* @Entity
* @Table(
* name="EMPLOYEE",
* uniqueConstraints=
* @UniqueConstraint(columnNames={"EMP_ID", "EMP_NAME"})
* )
* public class Employee { ... }
* </pre>
*
* @since Java Persistence 1.0
*/
@Target({TYPE})
@Retention(RUNTIME)
public @interface UniqueConstraint {
(Optional) Constraint name. A provider-chosen name will be chosen
if a name is not specified.
Returns: name Since: Java Persistence 2.0
/**
* (Optional) Constraint name. A provider-chosen name will be chosen
* if a name is not specified.
*
* @return name
* @since Java Persistence 2.0
*/
String name() default "";
(Required) An array of the column names that make up the constraint.
Returns: col names
/**
* (Required) An array of the column names that make up the constraint.
*
* @return col names
*/
String[] columnNames();
}