@Target(value={METHOD,FIELD})
@Retention(value=RUNTIME)
public @interface OrderColumn
The OrderColumn
annotation is specified on a
OneToMany or ManyToMany relationship or on an element
collection. The OrderColumn
annotation is specified on
the side of the relationship that references the collection that is
to be ordered. The order column is not visible as part of the state
of the entity or embeddable class.
The OrderBy
annotation should be used for ordering that
is visible as persistent state and maintained by the
application. The OrderBy
annotation is not used when
OrderColumn
is specified.
The order column must be of integral type. The persistence provider maintains a contiguous (non-sparse) ordering of the values of the order column when updating the association or element collection. The order column value for the first element is 0.
Example: @Entity public class CreditCard { @Id long ccNumber; @OneToMany // unidirectional @OrderColumn List<CardTransaction> transactionHistory; ... }
OrderBy
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.
|
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 ordering column.
|
boolean |
nullable
(Optional) Whether the database column is nullable.
|
boolean |
updatable
(Optional) Whether the column is included in SQL UPDATE statements
generated by the persistence provider.
|
public abstract java.lang.String name
public abstract boolean nullable
public abstract boolean insertable
public abstract boolean updatable
public abstract java.lang.String columnDefinition