more accurate cross-links in doc
This commit is contained in:
parent
d5184d07d0
commit
908630a7f2
|
@ -819,5 +819,5 @@ session.enableFetchProfile("org.hibernate.defaultProfile");
|
||||||
|
|
||||||
Then ``outer join``s for such associations will _automatically_ be added to every HQL or criteria query.
|
Then ``outer join``s for such associations will _automatically_ be added to every HQL or criteria query.
|
||||||
This is nice if you can't be bothered typing out those ``join fetch``es explicitly.
|
This is nice if you can't be bothered typing out those ``join fetch``es explicitly.
|
||||||
And in principle it even helps partially mitigate the <<many-to-one,problem>> of JPA having specified the wrong default for the `fetch` member of `@ManyToOne`.
|
And in principle it even helps partially mitigate the <<lazy-problem,problem>> of JPA having specified the wrong default for the `fetch` member of `@ManyToOne`.
|
||||||
====
|
====
|
||||||
|
|
|
@ -996,6 +996,7 @@ class Book {
|
||||||
|
|
||||||
Here, the `Book` table has a foreign key column holding the identifier of the associated `Publisher`.
|
Here, the `Book` table has a foreign key column holding the identifier of the associated `Publisher`.
|
||||||
|
|
||||||
|
[[lazy-problem]]
|
||||||
[TIP]
|
[TIP]
|
||||||
// .Almost all associations should be lazy
|
// .Almost all associations should be lazy
|
||||||
====
|
====
|
||||||
|
@ -1037,6 +1038,7 @@ Set<Book> books;
|
||||||
----
|
----
|
||||||
We're going to use this approach for the rest of the Introduction.
|
We're going to use this approach for the rest of the Introduction.
|
||||||
|
|
||||||
|
[[bidirectional-problem]]
|
||||||
[WARNING]
|
[WARNING]
|
||||||
// .To modify a bidirectional association, you must change the _owning side_!
|
// .To modify a bidirectional association, you must change the _owning side_!
|
||||||
====
|
====
|
||||||
|
@ -1120,7 +1122,7 @@ Here, the `Author` table has a foreign key column holding the identifier of the
|
||||||
====
|
====
|
||||||
A one-to-one association often models a "type of" relationship.
|
A one-to-one association often models a "type of" relationship.
|
||||||
In our example, an `Author` is a type of `Person`.
|
In our example, an `Author` is a type of `Person`.
|
||||||
An alternative—and often more natural—way to represent "type of" relationships in Java is via <<entity-inheritance>>.
|
An alternative—and often more natural—way to represent "type of" relationships in Java is via <<entity-inheritance,entity class inheritance>>.
|
||||||
====
|
====
|
||||||
|
|
||||||
We can make this association bidirectional by adding a reference back to the `Author` in the `Person` entity:
|
We can make this association bidirectional by adding a reference back to the `Author` in the `Person` entity:
|
||||||
|
|
|
@ -332,7 +332,7 @@ Now for the gotchas:
|
||||||
We're getting a bit ahead of ourselves here, but let's quickly mention the general strategy we recommend to navigate past these gotchas:
|
We're getting a bit ahead of ourselves here, but let's quickly mention the general strategy we recommend to navigate past these gotchas:
|
||||||
|
|
||||||
- All associations should be set `fetch=LAZY` to avoid fetching extra data when it's not needed.
|
- All associations should be set `fetch=LAZY` to avoid fetching extra data when it's not needed.
|
||||||
As we mentioned in <<many-to-one>>, this setting is not the default for `@ManyToOne` associations, and must be specified explicitly.
|
As we mentioned <<lazy-problem,earlier>>, this setting is not the default for `@ManyToOne` associations, and must be specified explicitly.
|
||||||
- But strive to avoid writing code which triggers lazy fetching.
|
- But strive to avoid writing code which triggers lazy fetching.
|
||||||
Instead, fetch all the data you'll need upfront at the beginning of a unit of work, using one of the techniques described in <<association-fetching>>, usually, using _join fetch_ in HQL or an `EntityGraph`.
|
Instead, fetch all the data you'll need upfront at the beginning of a unit of work, using one of the techniques described in <<association-fetching>>, usually, using _join fetch_ in HQL or an `EntityGraph`.
|
||||||
====
|
====
|
||||||
|
@ -1035,10 +1035,9 @@ In this section we'll quickly sketch some general strategies for avoiding "quagm
|
||||||
Hibernate is not about "transparent persistence" for Java objects.
|
Hibernate is not about "transparent persistence" for Java objects.
|
||||||
It's about making two excellent technologies work smoothly together.
|
It's about making two excellent technologies work smoothly together.
|
||||||
- <<logging-generated-sql,Log the SQL>> executed by Hibernate.
|
- <<logging-generated-sql,Log the SQL>> executed by Hibernate.
|
||||||
// Look, this seems obvious, until you've met users who didn't realize it was possible or useful.
|
|
||||||
You cannot know that your persistence logic is correct until you've actually inspected the SQL that's being executed.
|
You cannot know that your persistence logic is correct until you've actually inspected the SQL that's being executed.
|
||||||
Even when everything seems to be "working", there might be a lurking <<association-fetching,N+1 selects monster>>.
|
Even when everything seems to be "working", there might be a lurking <<association-fetching,N+1 selects monster>>.
|
||||||
- Be careful when <<many-to-one,modifying bidirectional associations>>.
|
- Be careful when <<bidirectional-problem,modifying bidirectional associations>>.
|
||||||
In principle, you should update _both ends_ of the association.
|
In principle, you should update _both ends_ of the association.
|
||||||
But Hibernate doesn't strictly enforce that, since there are some situations where such a rule would be too heavy-handed.
|
But Hibernate doesn't strictly enforce that, since there are some situations where such a rule would be too heavy-handed.
|
||||||
Whatever the case, it's up to you to maintain consistency across your model.
|
Whatever the case, it's up to you to maintain consistency across your model.
|
||||||
|
|
|
@ -424,7 +424,7 @@ Therefore, we arrive at this rule of thumb:
|
||||||
====
|
====
|
||||||
Many-to-one associations to "reference data", or to any other data that will almost always be available in the cache, should be mapped `EAGER`,`SELECT`.
|
Many-to-one associations to "reference data", or to any other data that will almost always be available in the cache, should be mapped `EAGER`,`SELECT`.
|
||||||
|
|
||||||
Other associations, as we've <<many-to-one,already made clear>>, should be `LAZY`.
|
Other associations, as we've <<bidirectional-problem,already made clear>>, should be `LAZY`.
|
||||||
====
|
====
|
||||||
|
|
||||||
Once we've marked an entity or collection as eligible for storage in the second-level cache, we still need to set up an actual cache.
|
Once we've marked an entity or collection as eligible for storage in the second-level cache, we still need to set up an actual cache.
|
||||||
|
|
Loading…
Reference in New Issue