0
table Student
----------------
id  | somecolumn with string| fk(which is self referencing ID of the same table)

我如何进行休眠查询,以获取 id 值与 fk 值匹配的所有项目。

这是我尝试过的,但它不起作用(它只返回 1 个结果而不是结果集)

List<Student> list = (List<Student>) sessionFactory
            .getCurrentSession()
            .createQuery("from Student p join p.studentFKs p2 where p2.id = :parentId")
            .setParameter("parentId", parentId).list();

有人可以帮我解决这个谜吗?我知道它也可以通过 Hibernate 标准来实现。

更新答案是将查询更改为(加入无效..):

select p from Student p join p.student p2 where p2.id = :parentId
4

1 回答 1

0

我用这样的东西,这是工作

实体 Student 内部连接的属性:

@ManyToMany(cascade = CascadeType.REFRESH)
private Set<Student> testJoins = new HashSet<Student>();

HQL 得到那个集合:

select a.testJoins from Student a where a.id = :parentId

也许您可以将查询从更改p2.id = :parentId为-->>p.id = :parentId

于 2013-07-20T08:56:53.853 回答