Я пытался создать приложение Java EE, я изо всех сил пытаюсь установить соединение с базой данных (я использую mysql), и я использую Payara 4. Я также пытался создать пул соединений на своем сервер, но он тоже не работал. Не могли бы вы дать мне несколько советов о том, что я должен изменить? Спасибо.
Это структура проекта: ![enter image description here](https://i.stack.imgur.com/YIUPu.png)
постоянство. xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1"
xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="Planner" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<!-- <class>model.Task</class>-->
<properties>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/planner"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password" value="root"/>
<!--Hibernate properties-->
<!-- <property name="hibernate.show_sql" value="false"/>-->
<!-- <property name="hibernate.format_sql" value="false"/>-->
<!-- <property name="hibernate.hbm2ddl.auto" value="create"/>-->
<!-- <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>-->
</properties>
</persistence-unit>
</persistence>
пом. xml
<?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>org.example</groupId>
<artifactId>planner-backend1</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.1-api</artifactId>
<version>1.0.0.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.3.5.Final</version>
</dependency>
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
<version>4.2.0</version>
<!-- scope is set to test, to avoid having the dependency in the wars -->
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<!-- this is the version, payara uses -->
<version>5.1.2.Final</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
А сущность Задачи и хранилище задач выглядят так:
@Entity(name = "task")
public class Task {
@Id
@GeneratedValue
private Long id;
@Column
private String description;
@Column
private String date;
хранилище
@Transactional(Transactional.TxType.SUPPORTS)
public class TaskRepository {
@PersistenceContext(unitName = "Planner")
private EntityManager entityManager;
public Task find(@NotNull Long id) {
return entityManager.find(Task.class, id);
}
public List<Task> findAll() {
TypedQuery<Task> query = entityManager.createQuery("SELECT b FROM Task b ORDER BY b.id DESC", Task.class);
return query.getResultList();
}
public Long countAll() {
TypedQuery<Long> query = entityManager.createQuery("SELECT count(b) FROM Task b", Long.class);
return query.getSingleResult();
}
@Transactional(Transactional.TxType.REQUIRED)
public void create(@NotNull Task task) {
entityManager.persist(task);
}
@Transactional(Transactional.TxType.REQUIRED)
public void delete(@NotNull Long id) {
entityManager.remove(entityManager.getReference(Task.class, id));
}
}