图中有空白节点的 SPARQL 查询海龟文件
SPARQL query turtle file with blank nodes in the graph
我正在尝试正确理解turtle中的空白节点,我需要知道我是否理解正确。
假设我们有一个海龟文件:
@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 .
}
这只会 return 人 1 的电子邮件,因为 ?x
绑定到空白节点标签 _:a
...所以我的问题是如果一个未定义的变量 ?x
仍然可以绑定到具有标签的空白节点,就像它不是空白时一样......所以在这个例子中,return 将是:
email
--------------------------
<mailto:email1@test.com> |
这样对吗?谢谢。
您猜对了:在这两种情况下(如前所述,我并没有真正看出您的两个示例之间的区别)答案将是 仅 人的电子邮件1.
从 SPARQL 的角度来看,空白节点与任何其他资源一样,它将以完全相同的方式将变量绑定到空白节点。所以在上面的例子中,因为我们知道这两个语句使用相同的空白节点作为它们的主题(因为它们使用相同的标签),所以它们将被 SPARQL 视为关于相同的主题。
一个警告:您使用的 SPARQL engine/triplestore 很可能不会保留特定的空白节点 ID a
:将数据添加到三元组时,它将被一些生成的内部 ID 替换.但是,triplestore 当然会确保文件中两次出现的 a
都被完全相同的生成 ID 替换。
我正在尝试正确理解turtle中的空白节点,我需要知道我是否理解正确。
假设我们有一个海龟文件:
@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 .
}
这只会 return 人 1 的电子邮件,因为 ?x
绑定到空白节点标签 _:a
...所以我的问题是如果一个未定义的变量 ?x
仍然可以绑定到具有标签的空白节点,就像它不是空白时一样......所以在这个例子中,return 将是:
email
--------------------------
<mailto:email1@test.com> |
这样对吗?谢谢。
您猜对了:在这两种情况下(如前所述,我并没有真正看出您的两个示例之间的区别)答案将是 仅 人的电子邮件1.
从 SPARQL 的角度来看,空白节点与任何其他资源一样,它将以完全相同的方式将变量绑定到空白节点。所以在上面的例子中,因为我们知道这两个语句使用相同的空白节点作为它们的主题(因为它们使用相同的标签),所以它们将被 SPARQL 视为关于相同的主题。
一个警告:您使用的 SPARQL engine/triplestore 很可能不会保留特定的空白节点 ID a
:将数据添加到三元组时,它将被一些生成的内部 ID 替换.但是,triplestore 当然会确保文件中两次出现的 a
都被完全相同的生成 ID 替换。