JPA — пример приложения Hello World. Настройка использования Spring + JPA + Hibernate. Часть 1
Описание стандарта Java Persistence API. В статье будет показано как настроить Spring + JPA + Hibernate и подключить к БД MySQL.
Используемые технологии
- Spring 4.1.5.RELEASE
- Hibernate 5.0.1.Final
- JPA 2.1
- MySQL 5.6.25
- IntelliJ IDEA 14
- Maven 3.2.5
1. Описание задачи
Создать проект с использованием Java Persistence API, Spring, Hibernate и подключить всё это к базе данных MySQL. Spring будет использоваться как базовая конфигурация проекта, предоставит аннотации и свяжет все фреймворки в одном месте. Hibernate будет поставщиком службы постоянства, а JPA станет основой для программирования доступа к данным.
2. Описание JPA
JPA — это стандарт программной модели ORM для JSE\JEE, в котором определен общий набор концепций, аннотаций, интерфейсов и других служб, которые поставщик постоянства должен реализовать (пакет javax.persistence). Эта стандартизация позволяет разработчикам переключаться между поставщиками постоянства, например между Hibernate, EclipseLink, Oracle TopLink, OpenJPA и другими. На разработку JPA достаточно сильно повлиял Hibernate и поэтому вы найдете много общего между ними. На данный момент рекомендуется использовать в проекте JPA в связке с поставщиком постоянства, например Hibernate. Именно это будет рассмотрено в этой статье.
3. Структура проекта
База данных MySQL и сущности взяты из статьи Hibernate – быстрый старт. Пример приложения Hello World. Рекомендую к прочтению её, а так же нескольких следующих статей из цикла по Hibernate, т.к. там есть описание подключения, настройки и базовых запросов, которые так же будут использованы в том или ином виде здесь.
4. Создание проекта
Вначале создаем пустой проект maven:
Затем необходимо настроить pom.xml:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>ru.javastudy</groupId> <artifactId>jpa_quickStart</artifactId> <version>1.0-SNAPSHOT</version> <properties> <hibernate-version>5.0.1.Final</hibernate-version> <spring-framework-version>4.1.5.RELEASE</spring-framework-version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-framework-bom</artifactId> <version>${spring-framework-version}</version> <scope>import</scope> <type>pom</type> </dependency> </dependencies> </dependencyManagement> <dependencies> <!--driver for connection to MYSql database --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.34</version> </dependency> <!-- Hibernate --> <!-- for JPA, use hibernate-entitymanager instead of hibernate-core. Support @PersistenceContext --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>${hibernate-version}</version> </dependency> <!-- Spring core and orm --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> </dependency> <!--support orm classes--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> </dependency> <!--support @Service, @Repository --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> </dependency> </dependencies> </project> |
Подписи к зависимостям говорят сами за себя. Первая зависимость Вначале идет общая ссылка на весь проект spring, а далее отдельно зависимости для драйвера подключения к БД MySQL, зависимость Hibernate, и три минимально необходимых библиотеки Spring.
4.1. Добавление поддержки фреймворков Hibernate, JPA
Нажимаем на название проекта правой кнопкой и выбираем Add Framework support..
Отмечаем галочкой Spring, JavaEE Persistence и Hibernate. Если зависимости подгрузились, то будет предложено выбрать библиотеку maven. После этого в проект добавятся необходимые xml — META-INF\persistence.xml и sping-config.xml.
ВАЖНО
По умолчанию spring-config.xml будет добавлен в корень, но как вы видите из структуры проекта он был перенесен в папку resources. Объяснение смотрите в главе немного ниже.
4.2 Настройка spring-config.xml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd" > <!--@Transaction annotation support --> <tx:annotation-driven transaction-manager="transactionManager"/> <!--Scanning components in base-package (look for annotations) --> <context:component-scan base-package="ru.javastudy"/> <!--Activates various annotations to be detected in bean classes: Spring's @Required and @Autowired and so on--> <context:annotation-config/> <!--Обеспечивает работу с транзакциями в Spring --> <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="emf"/> </bean> <!-- Datasource. Источник данных - база MySQL --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/javastudy" /> <property name="username" value="root" /> <property name="password" value="admin" /> </bean> <!-- EntityManagerFactory --> <bean id="emf" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="dataSource" ref="dataSource" /> <!--Поставщик данных - hibernate--> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" /> </property> <!--поиск сущностей в этом пакете--> <property name="packagesToScan" value="ru.javastudy"/> <!--детали конфигурации поставщика постоянства (hibernate) --> <property name="jpaProperties"> <props> <prop key="hibernate.dialect"> org.hibernate.dialect.H2Dialect </prop> <prop key="hibernate.max_fetch_depth">3</prop> <prop key="hibernate.jdbc.fetch_size">50</prop> <prop key="hibernate.jdbc.batch_size">10</prop> <prop key="hibernate.show_sql">true</prop> </props> </property> </bean> </beans> |
- Дескриптор tx:annotation-driven — предназначен для поддержки объявления требований к установлению границ транзакций с использованием аннотаций.
- context:component-scan — сканирование компонентов в указанном пакете и ниже
- context:annotation-config — включает поддержку таких аннотаций как @Require, @Autowired
- бин transactionManager — диспетчер транзакций для фабрики диспетчера сущностей
- EntityManagerFactory — самый главный бин:) В целом с ним и будем работать для доступа к данным
5. Подключение к базе данных MySQL
Полностью взято из статьи Создание MySQL базы данных и подключение к IntelliJ IDEA. Как заполнялись данные читайте в разделе Hibernate.
6. Добавление сущностей в Java, используя JPA + Hibernate
В целом процедура та же, что и для работы с Hibernate, только здесь в вкладке Persistence отсутствует hibernate, а есть только JPA.
Я выбрал добавление только аннотаций и генерацию свойств колонок и убрал галочку, отвечающую за создание xml файлов:
Продолжение
Продолжение настройки сущностей и базовые запросы читайте в JPA — пример приложения Hello World. Настройка использования Spring + JPA + Hibernate. Часть 2.
13
2 thoughts on “JPA — пример приложения Hello World. Настройка использования Spring + JPA + Hibernate. Часть 1”
Добавить комментарий
Для отправки комментария вам необходимо авторизоваться.
А можно подсказку?
Не совсем понимаю в какую сторону нужно гуглить.
Делал пункт 4.1, добавил поддержку фреймворков, а xmlки не сгенерировались вообще. Через «Project Structure» -> «Modules» вижу все три модуля(то-бишь спринг, гибернейт, JPA)
Выбираю JPA, там можно добавить META-INF\persistence.xml, но он считай что голый(выглядит вот так, поэтому думаю что он явно сгенерирован не так как надо, можно конечно руками все найти и прописать, для начала даже, наверное, полезно было бы, но все таки охота пользоваться сразу средствами среды).
(часть 2, жаль что длинные комменты сайт не пропускает)Причем в более ранней версии проекта(собственно делал по статье про быстрый старт с гибернейтом[понятно что файлы другие, но генерировались они нормально, причем это происходит с промежутком в полтора часа — закончил с той статьей, немного отдохнул и принялся за эту], только с другим драйвером и реализацией бд) все файлы генерировались нормально, надо было только дополнить конфигурацию для гибернейта, а тут вообще ничего, даже нормальной шапки нет…
Далее, конфигу для спринга думал так же на молодости сгенерировать, но не получилось, если выбрать этот модуль, то там немного о другом, и соответственно сгенерить, пусть даже и кривой файл я не могу. Если подскажете куда гуглить, будет хорошо, если сразу дадите прямой совет что и как делать(и где я накосячил), буду вообще рад(тут уж как вам удобнее). Использую Java SE, версия 15, идейка, hibernate 5.4.23.FINAL, spring 5.2.10.RELEASE, драйвер oracle.jdbc(тк пользуюсь оракловской реализацией бд, написал чисто на всякий случай)