Warm tip: This article is reproduced from serverfault.com, please click

protege-查找应该是实例 sparql 的类;

(protege - Finding classes which should be instances sparql; Finding classes with exactly 1 subclass)

发布于 2021-02-01 15:13:00

这听起来很简单,但我还没有找到一个很好的解决方案。我希望在我的本体中找到只有一个子类的类。

到目前为止,我的处理方式如下:

SELECT (COUNT(?anything) AS ?count) ?class
WHERE {
GRAPH <> {

    ?class rdf:type owl:Class.
    ?class rdfs:subClassOf ?anything.
    ?anything rdf:type owl:Class.
   
} group by ?class 

然后理论上我应该能够按计数排序,并且值为 1 的结果应该只有 1 个子类。但是,当我执行此查询时,计数与我期望的完全不符,例如我的测试用例应该返回 1,它确实如此,但是另一个根本没有子类的类也返回 1。和一个具有 3 个子类的类返回计数为 4。

在下图中,它应该会发现突出显示的类的计数为 1。 班级结构图

Questioner
Robin
Viewed
11
Joshua Taylor 2021-02-02 04:48:16

你正在寻找的 SPARQL 查询类似于

SELECT ?class WHERE {
  ?sub rdfs:subClassOf ?class
}
GROUP BY ?class 
HAVING (COUNT(DISTINCT ?sub) = 1)

但是,正如 UninformedUser 在评论中提到的那样,如果有可用的 OWL 推理,则可能会有很多你可能意想不到的答案,例如

owl:Nothing rdfs:subClassOf ex:YourClass

ex:YourClass rdfs:subClassOf ex:YourClass

如果这些阻止查询产生你正在寻找的结果,你应该添加一个过滤器,如

SELECT ?class WHERE {
  ?sub rdfs:subClassOf ?class
  FILTER ( ?sub != ?class && ?sub != owl:Nothing )
}
GROUP BY ?class 
HAVING (COUNT(DISTINCT ?sub) = 1)