jakarta.persistence.JoinTable
- Implemented Interfaces:
Annotation
- Target:
- Method, Field
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).
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.
If the JoinTable 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.
Example:
@JoinTable( name = "CUST_PHONE", joinColumns = @JoinColumn(name = "CUST_ID", referencedColumnName = "ID"), inverseJoinColumns = @JoinColumn(name = "PHONE_ID", referencedColumnName = "ID"))
This annotation may not be applied to a persistent field or property not annotated ManyToOne, OneToOne, ManyToMany, or OneToMany.
- See Also:
- Since:
- Jakarta Persistence (JPA) 1.0
Annotation Elements
String nameDefaults to the concatenated names of the two associated primary entity tables, separated by an underscore.
- Default:
- ""
- Since:
- Jakarta Persistence (JPA) 1.0
String catalogDefaults to the default catalog.
- Default:
- ""
- Since:
- Jakarta Persistence (JPA) 1.0
String schemaDefaults to the default schema for user.
- Default:
- ""
- Since:
- Jakarta Persistence (JPA) 1.0
Uses the same defaults as for JoinColumn.
- Default:
- {}
- Since:
- Jakarta Persistence (JPA) 1.0
Uses the same defaults as for JoinColumn.
- Default:
- {}
- Since:
- Jakarta Persistence (JPA) 1.0
foreignKey element of any of the joinColumns elements are specified, the behavior is undefined. If no foreign key annotation element is specified in either location, a default foreign key strategy is selected by the persistence provider.- Default:
- @ForeignKey(ConstraintMode.PROVIDER_DEFAULT)
- Since:
- Jakarta Persistence (JPA) 2.1
foreignKey element of any of the inverseJoinColumns elements are specified, the behavior is undefined. If no foreign key annotation element is specified in either location, a default foreign key strategy is selected by the persistence provider.- Default:
- @ForeignKey(ConstraintMode.PROVIDER_DEFAULT)
- Since:
- Jakarta Persistence (JPA) 2.1
Defaults to no additional constraints.
- Default:
- {}
- Since:
- Jakarta Persistence (JPA) 1.0
- Default:
- {}
- Since:
- Jakarta Persistence (JPA) 2.1
- Default:
- {}
- Since:
- Jakarta Persistence (JPA) 3.2
String comment- Default:
- ""
- Since:
- Jakarta Persistence (JPA) 3.2
String options- Default:
- ""
- Since:
- Jakarta Persistence (JPA) 3.2
Additional JDK methods inherited from java.lang.annotation.Annotation
annotationType(), equals(Object), hashCode(), toString()