JPA 2是否具有运行递归查询的任何机制?
这是我的情况:我有一个实体E,其中包含一个整数字段x。它还可能具有通过@OneToMany映射的E类型的子代。我想做的是通过主键找到一个E,并获取其x的值以及所有后代的x值。有没有办法在单个查询中执行此操作?
我正在使用Hibernate 3.5.3,但我不希望在Hibernate API上没有任何明确的依赖关系。
编辑:根据这一项目,Hibernate并 没有 具备这个功能,或者至少是在三月份没有。因此,JPA似乎不太可能拥有它,但我想确定一下。
使用简单的 邻接模型 ,其中每一行包含对其父级的引用,该引用将引用同一表中的另一行,因此与JPA不能很好地配合。这是因为JPA不支持使用Oracle
CONNECT BY子句或SQL标准WITH语句生成查询。如果没有这两个子句中的任何一个,则实际上不可能使邻接模型有用。
但是,有两种其他方法可以对此问题进行建模。首先是 物化路径模型 。这是将节点的完整路径展平为单个列的地方。表定义的扩展如下:
CREATE TABLE node (id INTEGER,
path VARCHAR,
parent_id INTEGER REFERENCES node(id));
插入节点树看起来像:
INSERT INTO node VALUES (1, '1', NULL); -- Root Node
INSERT INTO node VALUES (2, '1.2', 1); -- 1st Child of '1'
INSERT INTO node VALUES (3, '1.3', 1); -- 2nd Child of '1'
INSERT INTO node VALUES (4, '1.3.4', 3); -- Child of '3'
因此,要获取节点“ 1”及其所有子代,查询为:
SELECT * FROM node WHERE id = 1 OR path LIKE '1.%';
要将其映射到JPA,只需将“路径”列设置为持久对象的属性。但是,您将必须进行簿记以使“路径”字段保持最新。JPA /
Hibernate不会为您这样做。例如,如果将节点移动到其他父对象,则必须更新两个父引用,并从新的父对象确定新的路径值。
另一种方法称为 嵌套集模型
,这更复杂。最好由其创建者最好地描述(而不是由我逐字逐句地加以描述)。
第三种方法称为嵌套间隔模型,但是这种方法非常依赖于存储html" target="_blank">过程的实现。
SQL的艺术第7章介绍了对该问题的更完整的解释。
问题内容: 我有一组按层次结构组织的数据,应该可以增长到任意大小。我需要检索整个树,但是我无法弄清楚如何仅使用SQL来完成。我当前的解决方案是创建一个临时表,并使用递归函数依次查询树的分支,然后将结果存储在临时表中,随后我再次对其进行查询以产生所需的结果。 我的问题是,从本质上讲,我正在执行的联接正确吗?构造一个中间表,然后查询结果。似乎应该有一种使用联接的方法,但是MySQL文档仅涵盖检索有限深
问题内容: 我有下表: 我想让所有行都回溯,直到不再有parentID为止。因此, “ .... WHERE id = 5” 会给我: 问题答案: 您正在使用邻接表模型来组织层次结构数据。这种递归操作很困难的事实实际上是该模型的一个主要缺点。 一些DBMS(例如SQL Server 2005,Postgres 8.4和Oracle 11g)支持使用带有关键字的常用表表达式进行递归查询。 对于MyS
问题内容: 基于现有表,我使用了CTE递归查询来得出以下数据。但是无法进一步应用它。 数据如下 我想从上述数据递归形成完整路径。意味着递归将给出以下输出。 谢谢 问题答案: 以下是CTE的示例:
我试图创建一个包含问题的SQL关系,每个问题可以有一个或多个备选项,但当我从REST API调用它时,看看发生了什么:REST调用 以下是我的问题和备选模式: 模型
问题内容: 学习SQL,并有一些问题。我有2张桌子, 现在,我需要的是一个查询,该查询将基于标记要从哪个层次层次结构级别获取参数的参数,从每个层次结构级别返回表中的所有条目。 获取条目非常容易。 条目: 只是有父母的父母,而父母的父母是父母的父母,依此类推。这是我怀疑递归出现的地方。 有谁可以指导思想的吗? 问题答案: 您对第一级的查询(此处与表格区别)应如下所示: 请注意的正确用法(不要总是与进
问题内容: 我对PLSQL的更高级主题还是陌生的,因此希望有人可以帮助我。 问题: 我有一个表,其中包含管理员和用户之间发送的消息。该表在同一表的message_id字段中具有带FK的message_parent:如果填充了该字段,则意味着该消息是作为对先前消息的答复而发送的。我需要选择属于同一对话的所有消息并显示它们。可以通过单个查询完成此操作,还是需要一个过程来处理这种逻辑?据我了解,它必须是