是的,就像在普通SQL中一样,您可以指定要选择的属性类型:
SELECT i.firstProperty, i.secondProperty FROM ObjectName i WHERE i.id=10
执行此查询将返回Object []的列表,其中每个数组都包含一个对象的选定属性。
另一种方法是将所选属性包装在自定义对象中,然后在TypedQuery中执行它:
String query = "SELECT NEW CustomObject(i.firstProperty, i.secondProperty) FROM ObjectName i WHERE i.id=10";
TypedQuery typedQuery = em.createQuery(query , CustomObject.class);
List results = typedQuery.getResultList();
可以在本文中找到示例。
更新29.03.2018:
克里斯:
@PatrickLeitermann对我来说是“导致:org.hibernate.hql.internal.ast.QuerySyntaxException:无法找到类***”的异常。 如何解决呢?
我想您是在Spring应用程序的上下文中使用JPA,不是吗? 其他一些人也有完全相同的问题,他们的解决方案是在SELECT NEW关键字后添加完全限定名称(例如com.example.CustomObject)。
也许Spring数据框架的内部实现只能识别用@Entity注释的类或通过其简单名称在特定orm文件中注册的类,这导致使用此替代方法。