问题描述
背景
我有一个图形数据库,其中节点代表个人,边是谓词 hasMother 和 hasFather。我想确定所有共享一个母亲但不共享同一个父亲的节点。
尝试
在考虑这个问题时,有几个 SPARQL 术语会立即浮现在我的脑海中。即 Filter
、!=
和 NOT EXISTS
。
我首先开始并定义了一些集合...
令 M 为所有具有母亲 id,mother_id 的 winik 的集合。
令 F 是所有具有父亲 id、father_id 的 winik 的集合。
以下查询返回 M ∩ F 的 qraph。
PREFIX ex: <https://ex.com#>
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-Syntax-ns#>
CONSTRUCT WHERE {
?winik_id ex:hasMother ?mother_id.
?winik_id ex:hasFather ?father_id.
}
我的小问题是写排除部分(实际上我很难用语言表达我卡住的确切部分)-特别是如何处理查询的一般性(跨所有标识符)。
解决方法
这应该返回具有相同母亲但不同父亲的成对的人。
SELECT ?p1 ?p2 WHERE {
?p1 ex:hasMother ?m .
?p1 ex:hasFather ?f .
?p2 ex:hasMother ?m .
?p2 ex:hasFather ?f2 .
FILTER (?f != ?f2)