我将 OpenJPA 与 QueryDSL 一起使用,我尝试通过使用 QueryDSL 的 bean 投影功能来避免操作 Tuple 对象。例如,我有这两个实体,具有 @ManyToOne 关系。
@Entity
public class Folder {
private Long id;
private String name;
private String path;
@ManyToOne
@JoinColumn(name = "FK_FILE_ID")
private File file;
}
@Entity
public class File {
private Long id;
private String fileName;
}
当我执行此查询时:
List<Folder> listFolders = query.from(folder)
.list(Projections.bean(Folder.class, folder.name, folder.file.fileName));
我收到错误消息,指出文件夹对象不包含 fileName 属性。
我理解 QueryDSL 在做什么,因为它是一个简单的“平面”投影,但我想知道是否可以用查询找到的值填充我的folder.file对象的fileName属性。
注意:我知道我可以为我的文件夹类定义一个构造函数并使用此方法:
query.list(ConstructorExpression.create(Folder.class, folder.name,
folder.file.fileName));
但如果可能的话,我想避免这种情况,因为它迫使我为我在投影中想要的字段的 N 组合定义 N 构造函数。