You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
134 lines
4.3 KiB
134 lines
4.3 KiB
/* |
|
* 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 com.fr.third.javax.persistence; |
|
|
|
import java.lang.annotation.Retention; |
|
import java.lang.annotation.Target; |
|
|
|
import static java.lang.annotation.ElementType.FIELD; |
|
import static java.lang.annotation.ElementType.METHOD; |
|
import static java.lang.annotation.RetentionPolicy.RUNTIME; |
|
|
|
/** |
|
* Used in the mapping of associations. It is specified on the |
|
* owning side of an association. |
|
* |
|
* <p> A join table is typically used in the mapping of many-to-many |
|
* and unidirectional one-to-many associations. It may also be used to |
|
* map bidirectional many-to-one/one-to-many associations, |
|
* unidirectional many-to-one relationships, and one-to-one |
|
* associations (both bidirectional and unidirectional). |
|
* |
|
*<p>When a join table is used in mapping a relationship with an |
|
*embeddable class on the owning side of the relationship, the |
|
*containing entity rather than the embeddable class is considered the |
|
*owner of the relationship. |
|
* |
|
* <p> If the <code>JoinTable</code> annotation is missing, the |
|
* default values of the annotation elements apply. |
|
* The name of the join table is assumed to be the table names of the |
|
* associated primary tables concatenated together (owning side |
|
* first) using an underscore. |
|
* |
|
* <pre> |
|
* |
|
* Example: |
|
* |
|
* @JoinTable( |
|
* name="CUST_PHONE", |
|
* joinColumns= |
|
* @JoinColumn(name="CUST_ID", referencedColumnName="ID"), |
|
* inverseJoinColumns= |
|
* @JoinColumn(name="PHONE_ID", referencedColumnName="ID") |
|
* ) |
|
* </pre> |
|
* |
|
* @see JoinColumn |
|
* @see JoinColumns |
|
* |
|
* @since Java Persistence 1.0 |
|
*/ |
|
@Target({METHOD, FIELD}) |
|
@Retention(RUNTIME) |
|
|
|
public @interface JoinTable { |
|
|
|
/** |
|
* (Optional) The name of the join table. |
|
* |
|
* <p> Defaults to the concatenated names of |
|
* the two associated primary entity tables, |
|
* separated by an underscore. |
|
*/ |
|
String name() default ""; |
|
|
|
/** (Optional) The catalog of the table. |
|
* <p> Defaults to the default catalog. |
|
*/ |
|
String catalog() default ""; |
|
|
|
/** (Optional) The schema of the table. |
|
* <p> Defaults to the default schema for user. |
|
*/ |
|
String schema() default ""; |
|
|
|
/** |
|
* (Optional) The foreign key columns |
|
* of the join table which reference the |
|
* primary table of the entity owning the |
|
* association. (I.e. the owning side of |
|
* the association). |
|
* |
|
* <p> Uses the same defaults as for {@link JoinColumn}. |
|
*/ |
|
JoinColumn[] joinColumns() default {}; |
|
|
|
/** |
|
* (Optional) The foreign key columns |
|
* of the join table which reference the |
|
* primary table of the entity that does |
|
* not own the association. (I.e. the |
|
* inverse side of the association). |
|
* |
|
* <p> Uses the same defaults as for {@link JoinColumn}. |
|
*/ |
|
JoinColumn[] inverseJoinColumns() default {}; |
|
|
|
/** |
|
* (Optional) Unique constraints that are |
|
* to be placed on the table. These are |
|
* only used if table generation is in effect. |
|
* <p> Defaults to no additional constraints. |
|
*/ |
|
UniqueConstraint[] uniqueConstraints() default {}; |
|
|
|
/** |
|
* (Optional) Indexes for the table. These are only used if table generation is in effect. |
|
* |
|
* @return The indexes |
|
*/ |
|
Index[] indexes() default {}; |
|
|
|
/** |
|
* (Optional) Used to specify or control the generation of a foreign key constraint for the columns |
|
* corresponding to the joinColumns element when table generation is in effect. |
|
* |
|
* @since Java Persistence 2.1 |
|
*/ |
|
ForeignKey foreignKey() default @ForeignKey(ConstraintMode.PROVIDER_DEFAULT); |
|
|
|
/** |
|
* (Optional) Used to specify or control the generation of a foreign key constraint for the columns |
|
* corresponding to the inverseJoinColumns element when table generation is in effect. |
|
* |
|
* @since Java Persistence 2.1 |
|
*/ |
|
ForeignKey inverseForeignKey() default @ForeignKey(ConstraintMode.PROVIDER_DEFAULT); |
|
}
|
|
|