我有一个OWL文件,其中包含一个分类层次结构,我想写一个查询,其答案包括每个人及其直接分类父代。这里有一个例子(完整的查询比较混乱)。在SPARQL中删除不需要的超类答案
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix rdf: <http:://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix : <urn:ex:> .
:fido rdf:type :Dog .
:Dog rdfs:subClassOf :Mammal .
:Mammal rdfs:subClassOf :Vertebrate .
:Vertebrate rdfs:subClassOf :Animal .
:fido :hasToy :bone
:kitty rdf:type :Cat .
:Cat rdfs:subClassOf :Mammal .
:kitty :hasToy :catnipMouse .
而这个查询做我想要的。
prefix rdf: <http:://www.w3.org/1999/02/22-rdf-syntax-ns#> .
prefix : <urn:ex:> .
SELECT ?individual ?type
WHERE {
?individual :hasToy :bone .
?individual rdf:type ?type .
}
的问题是,我宁愿使用一个合理的,在OWL文件,其中包括意料之中附加声明的版本:
:fido rdf:type :Mammal .
:fido rdf:type :Vertebrate .
:fido rdf:type :Animal .
:kitty rdf:type :Mammal .
:kitty rdf:type :Vertebrate .
:kitty rdf:type :Animal .
现在约菲多是附加的答案查询结果哺乳动物等。我可以放弃使用合理版本的文件,或者,由于SPARQL查询是从java调用的,我可以做一堆附加查询来查找出现的最小包含类型。我的问题是,是否有合理的纯SPARQL解决方案只返回Dog解决方案。
您可能会在http://stackoverflow.com/q/19632992/1281433找到足够的答案。 –