Hibernate Criteria 运行时类

发布于 2024-12-06 00:47:17 字数 606 浏览 0 评论 0原文

这是我的层次结构:

// Table a
class A {}

// Table(" b
class B extends A {}

// Table my_class
class MyClass {

    A a;
}

我想从数据库中检索与 B 但不与 A 相关的所有 MyClass 对象。

B 是一个连接子类(表a 通过id 的扩展)。

我的想法是:

Criteria criteria = session.createCriteria(MyClass.class);
criteria.add(Restrictions.eq("a.class", B.class);

但它输出一个错误:

could not resolve property: a.class of a.b.MyClass

这是我可以表达的最简单的方式。请记住,查询有点复杂。

问候。

乌多.

This is my hierarchy:

// Table a
class A {}

// Table(" b
class B extends A {}

// Table my_class
class MyClass {

    A a;
}

I want to retrieve all MyClass objects from database with a relation to B but not to A.

B is a joined-subclass (extension of the table a by id).

My idea was something :

Criteria criteria = session.createCriteria(MyClass.class);
criteria.add(Restrictions.eq("a.class", B.class);

But it outputs an error:

could not resolve property: a.class of a.b.MyClass

This is the simplest way I could put it. Bear in mind that the query is a bit more complicated.

Regards.

Udo.

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

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

发布评论

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

评论(1

尐偏执 2024-12-13 00:47:17

我通常编写一个 DetachedCriteria 来选择所有 B 并过滤 MyClass,其中 A 在 AllB 中:(

DetachedCriteria allBs = DetachedCriteria
  .forClass(B.class)
  .setProjection( Projections.property("id") );

Criteria  criteria = session.createCriteria(MyClass.class)
  .add(Subqueries.In("a", allBs);

可能有错误,我不是 java 程序员。)

创建类似以下内容的内容:

select ...
from MyClass
where A in (select id from A inner join B on ...)

I usually write a DetachedCriteria which selects all B's and filter MyClass where A in AllBs:

DetachedCriteria allBs = DetachedCriteria
  .forClass(B.class)
  .setProjection( Projections.property("id") );

Criteria  criteria = session.createCriteria(MyClass.class)
  .add(Subqueries.In("a", allBs);

(There may be errors, I'm not a java programmer.)

Creates something like:

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