У меня есть сущность
@Entity
@Table(
name = SomeEntity.TABLE_NAME,
uniqueConstraints = {@UniqueConstraint(columnNames = {"first", "second"})}
)
public class SomeEntity extends SomeSuperEntity {
public static final String TABLE_NAME = "SomeEntity";
public SomeEntity() {
}
public SomeEntity(String first, String second, Integer third) {
super(first, second, third);
}
}
Суперкласс этой сущности
@MappedSuperclass
public abstract class SomeSuperEntity extends SomeSuperAbstractEntity {
@Column(nullable = false)
private String first;
@Column(nullable = false)
private String second;
protected SomeSuperEntity () {
}
protected SomeSuperEntity (String first, String second, Integer third) {
super(third);
this.first= first;
this.second= second;
}
}
Второй суперкласс
@MappedSuperclass
public abstract class SomeSuperAbstractEntity {
@Column(nullable = false)
private Integer third;
protected SomeSuperAbstractEntity () {
}
protected SomeSuperAbstractEntity (Integer third) {
this.third= third;
}
}
И у меня есть 2 метода, первый - для поиска сущности
public <T extends SomeSuperEntity > Optional<T> findByFirstAndSecond(String first, String second, Class<T> tClass) {
String hql = String.format("FROM %s E WHERE E.first = :first AND E.second = :second", getTable(tClass));
return jpaApi.em().createQuery(hql, tClass)
.setParameter("first", first)
.setParameter("second", second)
.getResultList().stream().findAny();
}
второй - для получения имени сущности в hql
private String getTable(Class<? extends SomeSuperEntity > tClass) {
if (tClass.equals(SomeEntity .class)) {
return SomeEntity.TABLE_NAME;
}
return null;
}
Когда я пытаюсь вызвать findByFirstAndSecond ("1", "2", SomeEntity.class), У меня ошибка
[ошибка] c .i.SomeMethod - ошибка: org.hibernate.hql.internal.ast.QuerySyntaxException: SomeEntity не отображается [ОТ SomeEntity E ГДЕ E.first = : first AND E.second =: second]