是否可以使用JPA查询从对象中仅选择属性A和B,而无需使用条件查询?
要选择所有属性,我只需要执行以下操作:
SELECT i FROM ObjectName i WHERE i.id = 10
但是我有一个在旧系统上具有许多属性的对象,并且即使我知道选择多个属性通常很快,也希望只选择其中一些。
不使用条件查询就可以吗?
谢谢!
是的,就像在普通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<CustomObject> typedQuery = em.createQuery(query , CustomObject.class);
List<CustomObject> results = typedQuery.getResultList();
例子中可以找到这个文章。
更新29.03.2018:
RishKrish:
@PatrickLeitermann对我来说是“导致:org.hibernate.hql.internal.ast.QuerySyntaxException:无法找到类***”的异常。如何解决呢?
我想您是在Spring应用程序的上下文中使用JPA,不是吗?其他一些人也有完全相同的问题,他们的解决方案是在SELECT NEW关键字之后添加完全限定名称(例如com.example.CustomObject)。
也许Spring数据框架的内部实现只能识别用@Entity注释的类或通过其简单名称在特定orm文件中注册的类,这导致使用此替代方法。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句