jpa 动态查询条件 数组_java-JPA查询仅选择特定列而不使用条件查询?

是的,就像在普通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文件中注册的类,这导致使用此替代方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值