@Target(value={METHOD,FIELD})
@Retention(value=RUNTIME)
public @interface JoinColumn
JoinColumn
annotation itself is
defaulted, a single join column is assumed and the default values
apply.
Example: @ManyToOne @JoinColumn(name="ADDR_ID") public Address getAddress() { return address; } Example: unidirectional one-to-many association using a foreign key mapping // In Customer class @OneToMany @JoinColumn(name="CUST_ID") // join column is in table for Order public Set<Order> getOrders() {return orders;}
ManyToOne
,
OneToMany
,
OneToOne
,
JoinTable
,
CollectionTable
,
ForeignKey
Modifier and Type | Optional Element and Description |
---|---|
java.lang.String |
columnDefinition
(Optional) The SQL fragment that is used when
generating the DDL for the column.
|
ForeignKey |
foreignKey
(Optional) Used to specify or control the generation of a
foreign key constraint when table generation is in effect.
|
boolean |
insertable
(Optional) Whether the column is included in
SQL INSERT statements generated by the persistence
provider.
|
java.lang.String |
name
(Optional) The name of the foreign key column.
|
boolean |
nullable
(Optional) Whether the foreign key column is nullable.
|
java.lang.String |
referencedColumnName
(Optional) The name of the column referenced by this foreign
key column.
|
java.lang.String |
table
(Optional) The name of the table that contains
the column.
|
boolean |
unique
(Optional) Whether the property is a unique key.
|
boolean |
updatable
(Optional) Whether the column is included in
SQL UPDATE statements generated by the persistence
provider.
|
public abstract java.lang.String name
Default (only applies if a single join column is used): The concatenation of the following: the name of the referencing relationship property or field of the referencing entity or embeddable class; "_"; the name of the referenced primary key column. If there is no such referencing relationship property or field in the entity, or if the join is for an element collection, the join column name is formed as the concatenation of the following: the name of the entity; "_"; the name of the referenced primary key column.
public abstract java.lang.String referencedColumnName
JoinTable
annotation,
the referenced key column is in the entity table of the owning
entity, or inverse entity if the join is part of the inverse
join definition.
CollectionTable
mapping, the
referenced column is in the table of the entity containing the
collection.
Default (only applies if single join column is being used): The same name as the primary key column of the referenced table.
public abstract boolean unique
UniqueConstraint
annotation at
the table level and is useful for when the unique key
constraint is only a single field. It is not necessary to
explicitly specify this for a join column that corresponds to a
primary key that is part of a foreign key.public abstract boolean nullable
public abstract boolean insertable
public abstract boolean updatable
public abstract java.lang.String columnDefinition
Defaults to the generated SQL for the column.
public abstract java.lang.String table
Default:
public abstract ForeignKey foreignKey