查找多个子类的不同属性

发布于 2024-11-18 15:11:11 字数 428 浏览 3 评论 0原文

我有 3 个实体 AgentPersonMachine

abstract Agent
  Long id

Person extends Agent
  String firstName
  String lastName

Machine extends Agent
   String label

我搜索了一个解决方案来根据给定参数 “name”< 查询我的所有代理/code>,它将查找 PersonfirstNamelastName,或者 Machine 的标签。

可以用jpql查询吗?

谢谢

I have 3 entities Agent, Person and Machine

abstract Agent
  Long id

Person extends Agent
  String firstName
  String lastName

Machine extends Agent
   String label

I searched for a solution to query all my agents on given parameter "name", which would lookup on firstName and lastName of Person, or on label of Machine.

Is it possible with a jpql query?

Thanks

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

云雾 2024-11-25 15:11:11

我有点晚了,但是自从querydsl 3.6.2(它纠正了instanceOf的使用)以来,你可以用java代码来做到这一点。

BooleanBuilder builder = new BooleanBuilder();
QAgent qAgent = QAgent.Agent;
builder.or(qAgent.as(QPerson.class).firstName.eq("someFirstName")
.and(qAgent.instanceOf(Person.class));

builder.or(qAgent.as(QMachine.class).label.eq("someLabel")
.and(qAgent.instanceOf(Machine.class));

Page<Agent> agentsPage = agentRepository.findAll(builder);

不利的一面是,我会重新考虑您的类结构,这将导致联合查询,如果您可以在超类上使用具有公共属性的投影,也许生成的查询会更便宜。

I am a little late but since querydsl 3.6.2(which corrected the use of instanceOf), you can do this with java code.

BooleanBuilder builder = new BooleanBuilder();
QAgent qAgent = QAgent.Agent;
builder.or(qAgent.as(QPerson.class).firstName.eq("someFirstName")
.and(qAgent.instanceOf(Person.class));

builder.or(qAgent.as(QMachine.class).label.eq("someLabel")
.and(qAgent.instanceOf(Machine.class));

Page<Agent> agentsPage = agentRepository.findAll(builder);

On the downside i would reconsider your class structure, this will result in union queries, if you could use a projection with common properties on the superclass maybe the resulting query would be less expensive.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文