Hibernate InheritanceType.JOINED предотвращает создание таблицы - PullRequest
0 голосов
/ 28 марта 2020

У меня есть два класса, «OrderBase» и «OrderPay», для которых я пытаюсь реализовать наследование типа «InheritanceType.JOINED».

Хотя TABLE_PER_CLASS и SINGLE_TABLE работают нормально, его нельзя создать как только я изменяю тип на «JOINED», и я не могу понять, почему.

Я удалил и заново создал схему при переключении типа наследования, чтобы убедиться, что это не проблема.

Это также происходит с любыми другими классами, для которых я пытаюсь реализовать наследование этого типа.

Моя стратегия создания таблицы - "create": spring.jpa.hibernate.ddl-auto = create

При изменении на «update» ошибка все равно будет сохраняться, даже если таблица существует в базе данных (до и после появления ошибки).

Я также создал новый проект, чтобы гарантировать, что ничто другое не мешает ему функционировать, и идентичная ошибка все еще происходит.

Я поделился проектом на github. Спецификации для создания схемы с mysql на локальном хосте находятся в файле application.properties: https://github.com/Danielmethner/brownbag

Здесь классы:

  1. OrderBase. java
package com.brownbag_api.model;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.Table;
import javax.validation.constraints.NotNull;

@Entity
@Table(name = "ORDER_BASE")
@Inheritance(strategy = InheritanceType.JOINED)
public class OrderBase implements Serializable {

    private static final long serialVersionUID = -3458221490393509305L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "ID")
    private Long id;

    @NotNull
    @Column(name = "AMOUNT")
    private double amount;

    public Order() {
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public double getAmount() {
        return amount;
    }

    public void setAmount(double amount) {
        this.amount = amount;
    }
}
OrderPay. java
package com.brownbag_api.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.validation.constraints.NotNull;

@Entity
public class OrderPay extends OrderBase  {

    private static final long serialVersionUID = 4643589803146964779L;

    @NotNull
    @Column(name = "BOOK_TEXT")
    private String bookText;

    public OrderPay() {
    }

    public String getBookText() {
        return bookText;
    }

    public void setBookText(String bookText) {
        this.bookText = bookText;
    }
}

Трассировка стека выглядит следующим образом (фактически сводится к «таблице родительского класса не найден»)

Причина: javax .persistence.PersistenceException: [PersistenceUnit: default] Невозможно построить Hibernate SessionFactory; вложенное исключение - org.hibernate.MappingException: не удалось создать экземпляр сохраняемого org.hibernate.persister.entity.JoinedSubclassEntityPersister, вызванного: org.hibernate.MappingException: не удалось создать экземпляр сохраняемого org.hibernate.persister.Jestister.Jister .AssertionFailure: Таблица brownbag.order_base не найдена

pom. 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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.brownbag</groupId>
    <artifactId>api</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>api</name>
    <description>API for brownbag project</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-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.9.1</version>
        </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>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.security</groupId>
            <artifactId>spring-security-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

1 Ответ

2 голосов
/ 28 марта 2020

У вас есть опечатка. Вероятно, вы наследуете от javax.persistence.criteria.Order.

Если вы измените свой OrderPay на расширение из правильного класса OrderBase, тогда все будет работать так, как ожидается, и будут созданы таблицы:

public class OrderPay extends OrderBase {

    //rest of code

}

Дополнительно, избавьтесь от этого свойства:

spring.jpa.properties.hibernate.default_schema=brownbag

Вы уже определили базу данных для подключения в spring.datasource.url.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...