我正在尝试获取一个类的最具体的属性,但我被卡住了。我想提取所有适用于给定类的属性(包括从超类继承的属性),但结果集中具有子属性的属性除外。
例如,如果我有一个类Population,其属性之一是atLocation,以及一个名为Refugees的Population子类。Refugees有一个属性currentLocation,它是atLocation的一个子属性。
所以我想要的是一个通用查询,如果我输入Population只会给我 atLocation,如果我输入Refugees只会给我currentLocation。我所拥有的是:
prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>
prefix ex: <http://example.org/vocabulary#>
SELECT DISTINCT ?prop WHERE {
ex:Refugee rdfs:subClassOf* ?domain .
?prop rdfs:domain ?domain .
?subprop rdfs:domain ?domain .
FILTER NOT EXISTS { ?subprop rdfs:subPropertyOf ?prop . }
} ORDER BY ?prop
不过,这给了我atLocation 和 currentLocation。
这可能在一个查询中吗?任何有关如何解决此问题的想法表示赞赏!