JPA查询仅选择特定列而不使用条件查询?

艾迪·伯恩(Edy Bourne)

是否可以使用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] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

使用JPA条件查询获取列的最大值

来自分类Dev

从SHOW ERRORS查询中选择特定的列

来自分类Dev

复杂条件查询:使用JPA代替NativeQuery

来自分类Dev

选择“与”条件查询

来自分类Dev

MySQL选择最大值而不使用子查询

来自分类Dev

仅查询特定列是否更快?

来自分类Dev

JPA条件联接查询

来自分类Dev

如何使用条件查询仅选择外键值?

来自分类Dev

休眠条件查询仅获取特定列

来自分类Dev

使用JPA本机查询与MemSql选择JSON列

来自分类Dev

如何使用Laravel从查询的嵌套关系中选择特定的列

来自分类Dev

如果我编写仅具有特定列的本机查询,如何使用Jpa在邮递员中显示列名

来自分类Dev

休眠条件查询以获取特定的列结果

来自分类Dev

在JPA条件API中使用子查询

来自分类Dev

选择使用列别名的查询

来自分类Dev

选择查询中的条件

来自分类Dev

SQL Server:选择查询上的条件列

来自分类Dev

MySQL选择条件查询

来自分类Dev

根据条件选择查询

来自分类Dev

JPA条件联接查询

来自分类Dev

选择查询特定的列值

来自分类Dev

MSSQL查询以仅选择基于条件的那些条目

来自分类Dev

SQL查询-指定如何选择特定列

来自分类Dev

不使用except查询

来自分类Dev

MySQL 选择查询使用 2 个条件

来自分类Dev

JPA 查询选择新

来自分类Dev

mysql 使用 where in 条件选择多个 avg 列并加入查询

来自分类Dev

如何使用 LINQ 使用联合查询从多个表中选择以仅返回一列?

来自分类Dev

JPA - 使用条件 JsonManagedReference 查询