Вставка вставок подкласса в таблицу суперкласса - PullRequest
0 голосов
/ 21 октября 2018

Я новичок, и я делаю некоторые упражнения по наследованию в спящем режиме.У меня есть два класса, суперкласс и подкласс, оба соединены наследованием SINGLE_TABLE.

Проблема заключается в том, что когда я хочу сохранить объект подкласса в базе данных, Hibernate пытается сделать «INSERT»в таблице суперкласса.И это приводит к ошибке «неизвестный столбец« цвет »в« списке полей »», поскольку столбец «цвет» не существует в таблице суперкласса.

Я не сопоставил связи между обеими таблицами.Должен ли я сделать это?Мои учебники не указывают это.В противном случае, что мне делать?

SUPERCLASS: --------------------------------------------------------------------

  @Entity
    @Table(name="autos")
    @Inheritance(strategy = InheritanceType.SINGLE_TABLE)
    @DiscriminatorColumn(
            name = "pe_discriminador",
            discriminatorType = DiscriminatorType.STRING)
    @DiscriminatorValue(value = "a1")

    public class auto implements Serializable{

    @Id  
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name="id")
    private int id;
    @Column(name="marca")
    private String marca;
    @Column(name="modelo")
    private String modelo;

    public auto(){

    }

        public auto(int id, String marca, String modelo) {
            this.id = id;
            this.marca = marca;
            this.modelo = modelo;
        }



        public long getId() {
            return id;
        }

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

        public String getMarca() {
            return marca;
        }

        public void setMarca(String marca) {
            this.marca = marca;
        }

        public String getModelo() {
            return modelo;
        }

        public void setModelo(String modelo) {
            this.modelo = modelo;
        }

        @Override
        public String toString() {
            return "auto{" + "id=" + id + ", marca=" + marca + ", modelo=" + modelo + '}';
        }





    }

SUBCLASS ----------------------------------------------------------------------

@Entity
@Table(name="autos")
@DiscriminatorValue("a2")
public class auto2 extends auto{

    int id2;
    public auto2() {
    }


    public auto2(int id2, String color, double motor, int id, String marca, String modelo) {
     this.id2=id2; 
     this.color=color; 
     this.motor=motor; 
     setMarca(marca); 
     setModelo(modelo);
    }



@Column(name="color")
private String color;
@Column(name="motor")
private double motor;



    public String getColor() {
        return color;
    }

    public void setColor(String color) {
        this.color = color;
    }

    public double getMotor() {
        return motor;
    }

    public void setMotor(double motor) {
        this.motor = motor;
    }

    @Override
    public String toString() {
        return "auto2{"  + ", color=" + color + ", motor=" + motor + '}';
    }
    }

ЖУРНАЛ ОШИБКИ HIBERNATE: ----------------------------------------------------------

INFO: HHH000115: Hibernate connection pool size: 20 (min=1)
oct 21, 2018 10:22:51 AM org.hibernate.dialect.Dialect <init>
INFO: HHH000400: Using dialect: org.hibernate.dialect.MySQLDialect
oct 21, 2018 10:22:52 AM org.hibernate.cfg.AnnotationBinder bindClass
WARN: HHH000139: Illegal use of @Table in a subclass of a SINGLE_TABLE hierarchy: entidades.auto2
Hibernate: insert into autos (marca, modelo, color, id2, motor, pe_discriminador) values (?, ?, ?, ?, ?, 'a2')
oct 21, 2018 10:22:54 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
WARN: SQL Error: 1054, SQLState: 42S22
oct 21, 2018 10:22:54 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
ERROR: Unknown column 'color' in 'field list'
Exception in thread "main" org.hibernate.exception.SQLGrammarException: could not execute statement
    at org.hibernate.exception.internal.SQLExceptionTypeDelegate.convert(SQLExceptionTypeDelegate.java:63)
    at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:113)
    at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:99)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:178)
    at org.hibernate.dialect.identity.GetGeneratedKeysDelegate.executeAndExtract(GetGeneratedKeysDelegate.java:57)
    at org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:42)
    at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3072)
    at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3663)
    at org.hibernate.action.internal.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:81)
    at org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:645)
    at org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:282)
    at org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:263)
    at org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:317)
    at org.hibernate.event.internal.AbstractSaveEventListener.addInsertAction(AbstractSaveEventListener.java:359)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:292)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:200)
    at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:131)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:192)
    at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:38)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:177)
    at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:32)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:73)
    at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:709)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:701)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:696)
    at testeo.TestAuto.main(TestAuto.java:225)
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'color' in 'field list'
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:425)
    at com.mysql.jdbc.Util.getInstance(Util.java:408)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:944)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3978)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3914)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2530)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2683)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2495)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1903)
    at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2124)
    at com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2058)
    at com.mysql.jdbc.PreparedStatement.executeLargeUpdate(PreparedStatement.java:5158)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2043)
    at org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:175)
    ... 22 more

1 Ответ

0 голосов
/ 21 октября 2018

0) Приквел к ответу

Прежде чем мы перейдем к ответу, я хотел бы отметить кое-что: пример кода выглядит немного грязно.Например, отступ может быть более интуитивно понятным, и, как правило, классы называются в PascalCase (то есть camelCase с заглавной первой буквой).Существует множество руководств по стилю, которые могут вам помочь (например, Google ).Поверьте: это делает кодирование более увлекательным!

1) Фактический ответ

Существует несколько стратегий для сохранения иерархий классов в режиме гибернации:

  • Одна таблица: все классы в иерархии сохраняются в одной таблице (с потенциально большим количеством столбцов)
  • Таблица на класс: каждый конкретный класс сохраняется в своей собственной таблице
  • Регистрация: каждый конкретный класса суперкласс сохраняется в таблице каждый

Вы выбрали SINGLE_TABLE стратегию наследования.Это означает, что все классы и подклассы, принадлежащие этой иерархии, будут сохранены в одной таблице ( таблица для иерархии классов ).

Из вашего описания ошибки кажется, что вашСхема базы данных, соответствует другой стратегии.

a) Таблица для стратегии класса

Если у вас есть одна таблица на конкретный подкласс (что означает: нет таблицы для абстрактного суперкласса), попробуйте:

@Entity
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public class Auto {

b) Присоединиться к стратегии

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

@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class Auto{
    @Id
    private int id;

    // getters, setters, ...
}

@Entity
@PrimaryKeyJoinColumn(name = "id")
public class RaceAuto extends Auto {
    // ...
}

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

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