我想使用DBPedia提取“心理学”的所有子类别(特别是,我认为此页是一个起点)。
在SPARQL端点中,我编写了这个查询,但它返回一个空集:
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
是根,我想从所有级别提取子类别(,),不仅仅是根的子级。以心理学为例,我如何做到这一点?
发布于 2016-06-02 16:01:39
(这个答案是对最初发布的问题的回答)
这个查询有三个问题。一个是rdfs:label
对象的语法,第二个是dct:subject
的方向。当这两个问题得到纠正后,您的查询将如下所示:
select distinct ?subject
where {
?concept rdfs:label "Branches of psychology"@en .
?concept ^dct:subject ?subject .
}
LIMIT 100
第三个是查询的性能。在这种情况下,如果增加执行超时,就会得到结果。它们在这里。
此外,我建议避免使用字符串的三重模式。它们容易出错。
https://stackoverflow.com/questions/37596172
复制相似问题