(finally) document sorted/ordered collections and map keys
This commit is contained in:
parent
715212c694
commit
7bec00cc86
|
@ -139,6 +139,10 @@ First, we must mark an entity as versioned, using the `@Audited` annotation:
|
||||||
@AuditTable("DocumentRevision")
|
@AuditTable("DocumentRevision")
|
||||||
class Document { ... }
|
class Document { ... }
|
||||||
----
|
----
|
||||||
|
[TIP]
|
||||||
|
====
|
||||||
|
The `@AuditTable` annotation is optional, and it's better to set either `org.hibernate.envers.audit_table_prefix` or `org.hibernate.envers.audit_table_suffix` and let the audit table name be inferred.
|
||||||
|
====
|
||||||
The `AuditReader` interface exposes operations for retrieving and querying historical revisions.
|
The `AuditReader` interface exposes operations for retrieving and querying historical revisions.
|
||||||
It's really easy to get hold of one of these:
|
It's really easy to get hold of one of these:
|
||||||
[source,java]
|
[source,java]
|
||||||
|
@ -612,6 +616,54 @@ sessionFactory.inTransaction(session -> {
|
||||||
----
|
----
|
||||||
====
|
====
|
||||||
|
|
||||||
|
[[ordered-sorted]]
|
||||||
|
=== Ordered and sorted collections and map keys
|
||||||
|
|
||||||
|
Java lists and maps don't map very naturally to foreign key relationships between tables, and so we tend to avoid using them to represent associations between our entity classes.
|
||||||
|
But if you feel like you _really_ need a collection with a fancier structure than `Set`, Hibernate does have options.
|
||||||
|
|
||||||
|
The first two options let us map the index of a `List` or key of a `Map` to a column:
|
||||||
|
|
||||||
|
.Annotations for mapping lists and maps
|
||||||
|
[%breakable,cols="22,~,^13"]
|
||||||
|
|===
|
||||||
|
| Annotation | Purpose | JPA-standard
|
||||||
|
|
||||||
|
| `@OrderColumn` | Specifies the column used to maintain the order of a list | ✔
|
||||||
|
| `@MapKeyColumn` | Specifies the column used to persist the keys of a map | ✔
|
||||||
|
|===
|
||||||
|
|
||||||
|
For an unowned association, the column must also be mapped on the owning side, usually by an attribute of the target entity.
|
||||||
|
|
||||||
|
Now, let's introduce a little distinction:
|
||||||
|
|
||||||
|
- an _ordered collection_ is one with an ordering maintained in the database, and
|
||||||
|
- a _sorted collection_ is one which is sorted in Java code.
|
||||||
|
|
||||||
|
These annotations allow us to specify how the elements of a collection should be ordered as they are read from the database:
|
||||||
|
|
||||||
|
.Annotations for ordered collections
|
||||||
|
[%breakable,cols="22,~,^13"]
|
||||||
|
|===
|
||||||
|
| Annotation | Purpose | JPA-standard
|
||||||
|
|
||||||
|
| `@OrderBy` | Specifies a fragment of JPQL used to order the collection | ✔
|
||||||
|
| `@SQLOrder` | Specifies a fragment of SQL used to order the collection | ✖
|
||||||
|
|===
|
||||||
|
|
||||||
|
On the other hand, the following annotation specify how a collection should be sorted in memory, and are used for collections of type `SortedSet` or `SortedMap`:
|
||||||
|
|
||||||
|
.Annotations for sorted collections
|
||||||
|
[%breakable,cols="22,~,^13"]
|
||||||
|
|===
|
||||||
|
| Annotation | Purpose | JPA-standard
|
||||||
|
|
||||||
|
| `@SortNatural` | Specifies that the elements of a collection are `Comparable` | ✖
|
||||||
|
| `@SortComparator` | Specifies a `Comparator` used to sort the collection | ✖
|
||||||
|
|===
|
||||||
|
|
||||||
|
Under the covers, Hibernate uses a `TreeSet` or `TreeMap` to maintain the collection in sorted order.
|
||||||
|
|
||||||
[[any]]
|
[[any]]
|
||||||
=== Any mappings
|
=== Any mappings
|
||||||
|
|
||||||
|
|
|
@ -1087,7 +1087,7 @@ In particular, the `List` may not contain duplicate elements, and its order will
|
||||||
Collection<Book> books;
|
Collection<Book> books;
|
||||||
----
|
----
|
||||||
|
|
||||||
(We'll see how to map a collection with a persistent order later.)
|
We'll see how to map a collection with a persistent order <<ordered-sorted,much later>>.
|
||||||
|
|
||||||
.`Set`, `List`, or `Collection`?
|
.`Set`, `List`, or `Collection`?
|
||||||
****
|
****
|
||||||
|
|
Loading…
Reference in New Issue