1

我使用以下代码创建芝麻本机 Java 商店:

创建本机 java 商店:

  // create a configuration for the SAIL stack
  boolean persist = true;
  String indexes = "spoc,posc,cspo";
  SailImplConfig backendConfig = new NativeStoreConfig(indexes);
  // stack an inferencer config on top of our backend-config
  backendConfig = new ForwardChainingRDFSInferencerConfig(backendConfig);
  // create a configuration for the repository implementation
  RepositoryImplConfig repositoryTypeSpec = new SailRepositoryConfig(backendConfig);
  RepositoryConfig repConfig = new RepositoryConfig(repositoryId, repositoryTypeSpec);
  repConfig.setTitle(repositoryId);
  manager.addRepositoryConfig(repConfig);
  Repository repository = manager.getRepository(repositoryId);

创建内存存储:

  // create a configuration for the SAIL stack
  boolean persist = true;
  SailImplConfig backendConfig = new MemoryStoreConfig(persist);
  // stack an inferencer config on top of our backend-config
  backendConfig = new ForwardChainingRDFSInferencerConfig(backendConfig);
  // create a configuration for the repository implementation
  RepositoryImplConfig repositoryTypeSpec = new SailRepositoryConfig(backendConfig);
  RepositoryConfig repConfig = new RepositoryConfig(repositoryId, repositoryTypeSpec);
  repConfig.setTitle(repositoryId);
  manager.addRepositoryConfig(repConfig);
  Repository repository = manager.getRepository(repositoryId);

当我将数据存储在此存储库中并进行查询时,结果与使用工作台创建的存储库返回的结果不同。我的结果集中出现重复/多个条目。

内存存储的行为相同。

我还观察到我的三元组属于空白上下文,这在通过工作台创建的存储库中不是这种情况。

我上面的代码有什么问题?

4

1 回答 1

0

据我所知,您的代码没有任何问题。如果从 Workbench 创建的商店表现不同,这很可能意味着它配置了不同的 SAIL 堆栈。

最有可能的差异是这一点:

// stack an inferencer config on top of our backend-config
backendConfig = new ForwardChainingRDFSInferencerConfig(backendConfig);

您已在此处为您的存储库配置了一个推理器。如果通过工作台创建的存储库使用推理器,您将在相同的查询上得到不同的结果(有时包括明显的重复结果)。

如果您认为这是一个问题,您可以通过两种方式解决此问题。一个是(当然)根本不创建带有推理器的存储库。另一种是禁用特定查询的推理。在 Workbench 中,您可以通过禁用查询屏幕中的“包括推断语句”复选框来执行此操作。以编程方式,您可以通过 Query.setIncludeInferred(false)在准备好的查询对象上使用来执行此操作。有关详细信息,请参阅javadoc

于 2013-06-27T04:32:03.020 回答