document new features for typesafety

This commit is contained in:
Gavin 2023-06-10 00:41:44 +02:00 committed by Christian Beikov
parent 3d6df8d296
commit b4bab0d2a3
4 changed files with 19 additions and 11 deletions

View File

@ -875,14 +875,11 @@ A fetch profile must be explicitly enabled for a given session:
[source,java] [source,java]
---- ----
session.enableFetchProfile("EagerBook"); session.enableFetchProfile(Book_.PROFILE_EAGER_BOOK);
Book eagerBook = session.find(Book.class, bookId); Book eagerBook = session.find(Book.class, bookId);
---- ----
[TIP] Here, once again, `BookQueries_.PROFILE_EAGER_BOOK` is generated by the Metamodel Generator, and is just a constant with the value `"EagerBook"`.
====
To make this a bit typesafe, it's a good idea to put the name of the fetch profile in a `static final` constant.
====
So why or when might we prefer named fetch profiles to entity graphs? So why or when might we prefer named fetch profiles to entity graphs?
Well, it's really hard to say. Well, it's really hard to say.

View File

@ -86,6 +86,8 @@ Where `{version}` is the latest version of the JDBC driver for your databse.
:infinispan: https://infinispan.org :infinispan: https://infinispan.org
:generator: https://hibernate.org/orm/tooling/ :generator: https://hibernate.org/orm/tooling/
:caffeine: https://github.com/ben-manes/caffeine/ :caffeine: https://github.com/ben-manes/caffeine/
:bean-validation: https://beanvalidation.org
:query-validator: https://github.com/hibernate/query-validator/
Optionally, you might also add any of the following additional features: Optionally, you might also add any of the following additional features:
@ -101,7 +103,8 @@ or `org.slf4j:slf4j-jdk14`
`org.hibernate.orm:hibernate-agroal` + `org.hibernate.orm:hibernate-agroal` +
and `io.agroal:agroal-pool` and `io.agroal:agroal-pool`
| The {generator}[Hibernate Metamodel Generator], especially if you're using the JPA criteria query API | `org.hibernate.orm:hibernate-jpamodelgen` | The {generator}[Hibernate Metamodel Generator], especially if you're using the JPA criteria query API | `org.hibernate.orm:hibernate-jpamodelgen`
| {validator}[Hibernate Validator] | | The {query-validator}[Query Validator], for compile-time checking of HQL | `org.hibernate:query-validator`
| {validator}[Hibernate Validator], an implementation of {bean-validation}[Bean Validation] |
`org.hibernate.validator:hibernate-validator` + `org.hibernate.validator:hibernate-validator` +
and `org.glassfish:jakarta.el` and `org.glassfish:jakarta.el`
| Local second-level cache support via JCache and {ehcache}[EHCache] | `org.hibernate.orm:hibernate-jcache` + | Local second-level cache support via JCache and {ehcache}[EHCache] | `org.hibernate.orm:hibernate-jcache` +
@ -443,7 +446,9 @@ We'll have more to say about them in <<naming-strategies>>.
[[nationalized-chars]] [[nationalized-chars]]
=== Nationalized character data in SQL Server === Nationalized character data in SQL Server
_By default,_ SQL Server's `char` and `varchar` types don't accommodate Unicode data. But a Java string may contain any Unicode character. So, if you're working with SQL Server, you might need to force Hibernate to use the `nchar` and `nvarchar` column types. _By default,_ SQL Server's `char` and `varchar` types don't accommodate Unicode data.
But a Java string may contain any Unicode character.
So, if you're working with SQL Server, you might need to force Hibernate to use the `nchar` and `nvarchar` column types.
.Setting the use of nationalized character data .Setting the use of nationalized character data
[%breakable,cols="40,~"] [%breakable,cols="40,~"]
@ -453,11 +458,11 @@ _By default,_ SQL Server's `char` and `varchar` types don't accommodate Unicode
| `hibernate.use_nationalized_character_data` | Use `nchar` and `nvarchar` instead of `char` and `varchar` | `hibernate.use_nationalized_character_data` | Use `nchar` and `nvarchar` instead of `char` and `varchar`
|=== |===
On the other hand, if only _some_ columns store nationalized data, use the `@Nationalized` annotation to indicate fields of your entities which map these columns.
[TIP] [TIP]
// .Configuring SQL Server to use UTF-8 by default // .Configuring SQL Server to use UTF-8 by default
==== ====
Alternatively, you can configure SQL Server to use the UTF-8 enabled collation `_UTF8`. Alternatively, you can configure SQL Server to use the UTF-8 enabled collation `_UTF8`.
==== ====
On the other hand, if only _some_ columns store nationalized data, use the `@Nationalized` annotation to indicate fields of your entities which map these columns.

View File

@ -904,7 +904,7 @@ var resultList = session.createSelectionQuery(query).getResultList();
for (var result: resultList) { for (var result: resultList) {
String title = result.get(bookTitle); String title = result.get(bookTitle);
String isbn = result.get(bookIsbn); String isbn = result.get(bookIsbn);
BigDecimal price = result.get(bookPrice); BigDecimal price = result.get(bookPrice);
... ...
} }
---- ----
@ -947,11 +947,13 @@ We execute our named query as follows:
[source,java] [source,java]
---- ----
List<Book> books = List<Book> books =
entityManager.createNamedQuery("10BooksByTitle") entityManager.createNamedQuery(BookQueries_.QUERY_10_BOOKS_BY_TITLE)
.setParameter("titlePattern", titlePattern) .setParameter("titlePattern", titlePattern)
.getResultList() .getResultList()
---- ----
Here, `BookQueries_.QUERY_10_BOOKS_BY_TITLE` is generated by the Metamodel Generator, and is just a constant with the value `"10BooksByTitle"`.
Note that the code which executes the named query is not aware of whether the query was written in HQL or in native SQL, making it slightly easier to change and optimize the query later. Note that the code which executes the named query is not aware of whether the query was written in HQL or in native SQL, making it slightly easier to change and optimize the query later.
[[load-access]] [[load-access]]

View File

@ -234,6 +234,10 @@ dependencies {
// JPA metamodel generator (for criteria queries) // JPA metamodel generator (for criteria queries)
annotationProcessor 'org.hibernate.orm:hibernate-jpamodelgen:6.2.2.Final' annotationProcessor 'org.hibernate.orm:hibernate-jpamodelgen:6.2.2.Final'
// Compile-time checking for HQL
//implementation 'org.hibernate:query-validator:2.0-SNAPSHOT'
//annotationProcessor 'org.hibernate:query-validator:2.0-SNAPSHOT'
// H2 database // H2 database
runtimeOnly 'com.h2database:h2:2.1.214' runtimeOnly 'com.h2database:h2:2.1.214'
} }