Я пытаюсь обновить схему базы данных из defend JpaEntities, но весенняя загрузка не может генерировать таблицы базы данных. Журнальный файл:
файл application.properties:
spring.datasource.url= jdbc:mysql://localhost:3306/banque_db
spring.datasource.username= root
spring.datasource.password=
spring.datasource.driver-class-name= com.mysql.cj.jdbc.Driver
spring.jpa.hibernate.ddl-auto= update
spring.jpa.show-sql= true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
класс сущности клиента:
@Entity(name = "client")
public class Client implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long code;
private String name;
private String email;
@OneToMany(mappedBy = "compte")
private Collection<Compte> comptes;
// + getters and setters
пом.xml
<?xml version = "1.0" encoding = "UTF-8"?>
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0 org.springframework.boot весна-загрузка-стартер-родитель 2.1.0.ВЫПУСК ком.Туто
<artifactId>MaBanque</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>MaBanque</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
Вы должны установить spring.jpa.hibernate.ddl-auto = create
для создания БД или create-drop
Дополнительные сведения см. в статье документы.
Первая проблема:
application.properties
файл:
spring.jpa.hibernate.ddl-auto = update
, он не создаст для вас схему. Вместо этого будет, знаете ли, Обновить существующая база данных, которой у вас сейчас нет.spring.jpa.hibernate.ddl-auto
равно create-drop
, но вы переопределяете его.src/main/resources
папка.
==> вы должны исправить:
spring.jpa.hibernate.ddl-auto = create - drop
Вторая проблема: класс сущности. Вы должны добавить @Столбец поверх атрибутов, например:
`@Entity(name = "client")
public class Client implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@Column
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long code;
@Column
private String name;
@Column
private String email;
@OneToMany(mappedBy = "compte")
private Collection<Compte> comptes;
// + getters and setters`
на самом деле проблема заключалась в том, что классы сущностей не были в правильном пакете. org.example, который содержит основной класс и org.entities по какой-то причине весенняя загрузка не сгенерировала таблицы, поэтому, когда я переместил пакет сущностей, чтобы он стал похож на org.example.entities и запустил приложение, все таблицы были успешно сгенерированы. спасибо, ребята, за помощь, я ценю :)