Spring boot не может генерировать таблицы в базе данных mysql

Я пытаюсь обновить схему базы данных из 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>

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
2
0
2 926
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Вы должны установить spring.jpa.hibernate.ddl-auto = create для создания БД или create-drop

Дополнительные сведения см. в статье документы.

Первая проблема: application.properties файл:

  1. Если вы установите атрибут spring.jpa.hibernate.ddl-auto = update, он не создаст для вас схему. Вместо этого будет, знаете ли, Обновить существующая база данных, которой у вас сейчас нет.
  2. Значение По умолчанию для spring.jpa.hibernate.ddl-auto равно create-drop, но вы переопределяете его.
  3. Ваше application.properties должен находится в

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 и запустил приложение, все таблицы были успешно сгенерированы. спасибо, ребята, за помощь, я ценю :)

Другие вопросы по теме