我想使用DBPedia提取“心理学”的所有子类别(特别是,我认为this page为起点)。
在SPARQL endpoint我写了这个查询,但它返回一个空集:
PREFIX dbo: <http://dbpedia.org/ontology/>
PREFIX dbp: <http://dbpedia.org/property/>
SELECT ?branch ?discipline
WHERE
{
?branch a yago:BranchesOfPsychology
OPTIONAL { ?branch dbo:academicDiscipline ?discipline }
}
ORDER BY ?branch
此查询提取所有直接子类别。
假设Branches of psychology
是一个根,我想从所有级别中提取子类别,不仅提取根的直接子级。我怎么能以心理学为榜样呢?
答案 0 :(得分:3)
(这个答案是最初发布的问题)
此查询存在三个问题。一个是rdfs:label
对象的语法,第二个是dct:subject
的方向。当这两个更正后,您的查询将如下所示:
select distinct ?subject
where {
?concept rdfs:label "Branches of psychology"@en .
?concept ^dct:subject ?subject .
}
LIMIT 100
第三个是查询的性能。在您的情况下,如果增加执行超时,您将获得结果。 Here they are
此外,我建议避免使用字符串的三重模式。它们容易出错。