0

我正在尝试正确理解海龟中的空白节点,我需要知道我是否正确理解了它们。

假设我们有一个海龟文件:

@prefix sn: <....some uri...> .
_:a sn:name "person1";
sn:email "email1@test.com" .
_:b sn:name "person2";
sn:email "email2@test.com" .
_:c sn:name "person3" .

我们有 SPARQL 查询:

PREFIX sn: <...some uri...>
SELECT ?email WHERE {
?x sn:name "person1" .
?x sn:email ?email .
}

这只会返回人 1 的电子邮件,因为?x绑定到空白节点标签_:a......所以我的问题是,未定义的变量是否?x仍然可以绑定到具有标签的空白节点,就像它不是空白时一样。 .. 所以在这个例子中,返回将是:

      email
--------------------------
<mailto:email1@test.com> |

那会是正确的吗?谢谢。

4

1 回答 1

1

您猜对了:在这两种情况下(正如我所说,我并没有真正看到您的两个示例之间的区别)答案将只是第 1 个人的电子邮件。

从 SPARQL 的角度来看,空白节点与其他任何资源一样,它将以完全相同的方式将变量绑定到空白节点。所以在上面的例子中,因为我们知道这两个语句使用相同的空白节点作为它们的主题(因为它们使用相同的标签),所以它们将被 SPARQL 视为大约相同的主题。

一个警告:您使用的 SPARQL 引擎/triplestore 很可能不会保留特定的空白节点 id a:当将您的数据添加到 Triplestore 时,它​​将被一些生成的内部 id 替换。但是,三重存储当然会确保a文件中出现的两个 都被完全相同的生成 id 替换。

于 2015-12-09T20:17:33.790 回答