这是一个场景。用户(web环境)可以用外语导入文档。当显示文档时,应用程序突出显示用户尚不知道的单词。然后,用户可以标记一些已知的单词,并将它们添加到他的字典中。
因此,基本上我们有一个表示文档中单词的String列表,以及一组表示用户已知单词的String(他的字典)。现在,对于List (文档)中的每个字符串,我们需要确定单词是否存在于集合中。听起来很简单,但是应该如何在数据库中建模呢?
这组已知的单词需要是持久化的,允许用户在每个会话中添加单词。这组已知的单词可能会长到上千个字符串。输入的文档可以有数百个单词。
我看到了两种解决方案,它们都不是很好的扩展。我为每个用户创建了一个字典类,其中包含一组已知的单词。
@PersistenceCapable(identityType=IdentityType.APPLICATION)
public class UserDictionary {
@PrimaryKey
@Persistent(valueStrategy=IdGeneratorStrategy.IDENTITY)
Long id;
@Persistent String userId;
@Persistent Set<String> knownWords;
}我不喜欢above...any的任何其他想法?
发布于 2010-09-09 12:36:29
你为什么要在数据库中建模呢?相反,将整个文档和整个字典加载到内存中,并在其中执行。
https://stackoverflow.com/questions/3612674
复制相似问题