SPARQL“不同于”

问题描述

背景

我有一个图形数据库,其中节点代表个人,边是谓词 hasMotherhasFather。我想确定所有共享一个母亲但共享同一个父亲的节点。

尝试

在考虑这个问题时,有几个 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)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...