document new features for typesafety
This commit is contained in:
parent
3d6df8d296
commit
b4bab0d2a3
|
@ -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.
|
||||||
|
|
|
@ -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.
|
|
||||||
|
|
||||||
|
|
|
@ -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]]
|
||||||
|
|
|
@ -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'
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue