more accurate cross-links in doc

This commit is contained in:
Gavin 2023-05-25 11:46:10 +02:00
parent d5184d07d0
commit 908630a7f2
4 changed files with 7 additions and 6 deletions

View File

@ -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`.
==== ====

View File

@ -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:

View File

@ -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.

View File

@ -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.