Herança de tabela única SEM coluna discriminadora

Bom dia, meus queridos camaradas,

Isso está começando a ser irritante - uma coisa simples, mas horas de luta, estou ficando velho

Estou tentando mapear duas classes para uma única tabela usando o JPA do Hibernate. A idéia é ter apenas um pequeno subconjunto de colunas na classe pai e um conjunto maior / completo na classe filho. Não há herança de TABLE envolvida, apenas herança de classe. Como pode ser isto alcançado?

Fazer isso não funcionará:

@Entity
@Table(name = "the_table")
class Parent implements Serializable {
}

@Entity
@Table(name = "the_table")
class Child extends Parent implements Serializable {
}

@Hibernate assume a estratégia de herança padrão InheritanceType.SINGLE_TABLE e está procurando a coluna discriminadora - DTYPE por padrão. Mas espere - não há herança de tabela, pois a coluna discriminadora não faz sentid

Também dei uma olhada no PolymorphismType.EXPLICIT, que não fez nenhuma diferença. O rastreamento de pilha é:

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'apprentice0_.DTYPE' in 'where clause'
   at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
   at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
   at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
   at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
   at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
   at com.mysql.jdbc.Util.getInstance(Util.java:386)
   at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1052)
   at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3597)
   at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3529)
   at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1990)
   at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2151)
   at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2625)
   at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2119)
   at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2281)
   at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeQuery(NewProxyPreparedStatement.java:76)
   at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:208)
   at org.hibernate.loader.Loader.getResultSet(Loader.java:1808)
   at org.hibernate.loader.Loader.doQuery(Loader.java:697)
   at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:259)
   at org.hibernate.loader.Loader.loadEntity(Loader.java:1881)

sim, mais uma coisa:

O@MappedSuperclass e@Embeddable não servem para nada, pois não podem ser usados em conjunto com@Entity - a classe pai deve ser um@Entity em si, pois está sendo usado para persistência em outro luga

questionAnswers(4)

yourAnswerToTheQuestion