diff --git a/framework-docs/modules/ROOT/pages/core/aot.adoc b/framework-docs/modules/ROOT/pages/core/aot.adoc index 106cae3959cb..e3c8c985b2ab 100644 --- a/framework-docs/modules/ROOT/pages/core/aot.adoc +++ b/framework-docs/modules/ROOT/pages/core/aot.adoc @@ -318,6 +318,51 @@ Java:: ---- ====== +[[aot.bestpractices.jpa]] +=== JPA + +The JPA persistence unit has to be known upfront for certain optmizations to apply. Consider the following basic example: + +[tabs] +====== +Java:: ++ +[source,java,indent=0,subs="verbatim,quotes",role="primary"] +---- + @Bean + LocalContainerEntityManagerFactoryBean customDBEntityManagerFactory(DataSource dataSource) { + LocalContainerEntityManagerFactoryBean factoryBean = new LocalContainerEntityManagerFactoryBean(); + factoryBean.setDataSource(dataSource); + factoryBean.setPackagesToScan("com.example.app"); + return factoryBean; + } +---- +====== + +To make sure the scanning occurs ahead of time, a `PersistenceManagedTypes` bean must be declared and used by the +factory bean definition, as shown by the following example: + +[tabs] +====== +Java:: ++ +[source,java,indent=0,subs="verbatim,quotes",role="primary"] +---- + @Bean + PersistenceManagedTypes persistenceManagedTypes(ResourceLoader resourceLoader) { + return new PersistenceManagedTypesScanner(resourceLoader) + .scan("com.example.app"); + } + + @Bean + LocalContainerEntityManagerFactoryBean customDBEntityManagerFactory(DataSource dataSource, PersistenceManagedTypes managedTypes) { + LocalContainerEntityManagerFactoryBean factoryBean = new LocalContainerEntityManagerFactoryBean(); + factoryBean.setDataSource(dataSource); + factoryBean.setManagedTypes(managedTypes); + return factoryBean; + } +---- +====== [[aot.hints]] == Runtime Hints