Как использовать аннотацию @ConstructorResult
У меня есть собственный запрос и я хочу отобразить результат выполнения запроса в список классов NON-Entity POJO:
@SqlResultSetMapping(
name = "SomeMapping",
classes = {
@ConstructorResult(targetClass = SomeClass.class,
columns = {
@ColumnResult(name = "id", type = Integer.class),
@ColumnResult(name = "NAME", type = String.class),
@ColumnResult(name = "DATE_BEGIN", type = java.util.Date.class)
}
)
}
)
public class SomeClass{
private Integer id;
private String name;
private java.util.Date begDate;
private java.util.Date endDate;
public SomeClass(Integer id, String name, Date begDate){
this.id = id;
this.name = name;
this.begDate = begDate;
}
//Getters & Setters ...
}
И вообще, как я хочу получить результат выполнения запроса:
String query = "SELECT " +
"A.id AS 'id', " +
"A.name AS 'NAME', " +
"A.begDate AS 'DATE_BEGIN' " +
"FROM " +
"SomeTable A " +
"WHERE A.endDate < '2014-01-01'";
List<SomeClass> result = em.createNativeQuery(query, "SomeMapping").getResultList();
Но я всегда получаю Список объектов. Как получить список моих POJO-ов?
2 ответа
Невозможно воспроизвести, но в вашем коде есть проблемы.
- добавлять
@SqlResultSetMapping
на классах сущностей - не заключайте в кавычки имя псевдонима столбца с
'
import java.util.Date;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@NoArgsConstructor
@AllArgsConstructor
@Data
public class SomeClass {
private int id;
private String name;
private Date dateBegin;
}
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.ColumnResult;
import javax.persistence.ConstructorResult;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.SqlResultSetMapping;
import javax.persistence.Table;
import lombok.Getter;
@SqlResultSetMapping(
name = "SomeMapping",
classes = {
@ConstructorResult(targetClass = SomeClass.class,
columns = {
@ColumnResult(name = "id", type = Integer.class),
@ColumnResult(name = "NAME", type = String.class),
@ColumnResult(name = "DATE_BEGIN", type = java.util.Date.class)
})
})
@Entity
@Table(name = "sometable")
@Getter
public class SomeEntity {
@Id
@Column(name = "id")
private Integer id;
@Column(name = "name")
private String name;
@Column(name = "begdate")
private Date begDate;
@Column(name = "enddate")
private Date endDate;
}
final String query = "SELECT " +
"A.id AS id, " +
"A.name AS NAME, " +
"A.begDate AS DATE_BEGIN " +
"FROM " +
"SomeTable A " +
"WHERE A.endDate < '2014-01-01'";
final List<SomeClass> result = em.createNativeQuery(query, "SomeMapping").getResultList();
Попробуйте переместить @SqlResultSetMapping
сущность на сущности.