【发布时间】:2011-10-22 04:50:11
【问题描述】:
我正在从 PHP/MySQL 迁移到 Google App Engine,并使用 JDO 作为与数据存储区的接口。将启用了修改前序树遍历 (MPTT) 的表迁移到 JDO 模型的推荐方法是什么?
【问题讨论】:
-
为什么选择 MPTT?在大多数情况下,祖先列表可能是更好的选择。
标签: java google-app-engine jdo mptt
我正在从 PHP/MySQL 迁移到 Google App Engine,并使用 JDO 作为与数据存储区的接口。将启用了修改前序树遍历 (MPTT) 的表迁移到 JDO 模型的推荐方法是什么?
【问题讨论】:
标签: java google-app-engine jdo mptt
在花了一些时间搜索在 GAE 数据存储上实现分层数据存储的不同方法后,我决定尝试直接 MPTT 实现。以下代码 sn -p 呈现模型:
@PersistenceCapable(identityType = IdentityType.APPLICATION)
public class MPTTObject {
@PrimaryKey
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY)
@Extension(vendorName = "datanucleus", key = "gae.encoded-pk", value = "true")
private String encodedKey;
@Persistent
private String parentEncodedKey;
@Persistent
private int left;
@Persistent
private int right;
如果数据存储操作是读取密集型的,该解决方案效果很好,但当操作是写入密集型时,它就相当“繁重”了。这一事实与必须在 GAE 中完成操作的时间限制相结合,使得该解决方案的吸引力降低。
另一种似乎更有效的方法是为层次结构中的每个节点存储父子节点的完整列表。
有关 GAE 数据存储上的分层数据存储的一些有用链接如下:
【讨论】:
Key 对象。
您可以查看 MPTT 的这个 JPA 实现,并将相同的想法应用于 JDO:
【讨论】: