停止 w=10=sh
SPARQL "Different Than"
背景
我有一个图形数据库,其中节点代表个人,边是谓词 hasMother 和 hasFather。我想识别共享一个母亲的所有节点,但不要共享同一个父亲。
尝试
在考虑这个问题时,我的脑海中会立即浮现出一些 SPARQL 术语。即 Filter
、!=
和 NOT EXISTS
.
我先着手定义了一些集合...
令 M 为所有具有母亲 ID 的 winiks 的集合,mother_id。
设 F 为所有具有父亲 ID 的 winiks 的集合,father_id。
下面查询returns一个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.
}
我的小问题是编写排除部分(实际上我很难用语言表达我卡住的确切部分)-特别是如何处理查询的通用性(跨所有标识符)。
这应该return对同母异父的人。
SELECT ?p1 ?p2 WHERE {
?p1 ex:hasMother ?m .
?p1 ex:hasFather ?f .
?p2 ex:hasMother ?m .
?p2 ex:hasFather ?f2 .
FILTER (?f != ?f2)
背景
我有一个图形数据库,其中节点代表个人,边是谓词 hasMother 和 hasFather。我想识别共享一个母亲的所有节点,但不要共享同一个父亲。
尝试
在考虑这个问题时,我的脑海中会立即浮现出一些 SPARQL 术语。即 Filter
、!=
和 NOT EXISTS
.
我先着手定义了一些集合...
令 M 为所有具有母亲 ID 的 winiks 的集合,mother_id。
设 F 为所有具有父亲 ID 的 winiks 的集合,father_id。
下面查询returns一个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.
}
我的小问题是编写排除部分(实际上我很难用语言表达我卡住的确切部分)-特别是如何处理查询的通用性(跨所有标识符)。
这应该return对同母异父的人。
SELECT ?p1 ?p2 WHERE {
?p1 ex:hasMother ?m .
?p1 ex:hasFather ?f .
?p2 ex:hasMother ?m .
?p2 ex:hasFather ?f2 .
FILTER (?f != ?f2)