我希望获取给定节点到给定深度
k level
的子图,如下图所示,k=2。
如果我访问 https://dbpedia.org/sparql 并选择
?city
我想获取城市图的所有详细信息(例如 5 个级别)。我正在寻找一个通用查询,不需要了解图表即可获取如下数据。
CONSTRUCT {
?city a ?plebs .
?mayor foaf:gender ?gender.
?city dbo:country ?ctr .
?city dbo:populationTotal ?pop.
?city dbo:leaderParty ?party .
?city rdfs:label ?cityName .
?party dbo:ideology ?ideology
} WHERE {
?plebs rdfs:subClassOf dbo:Settlement.
?city a ?plebs .
?city (dbp:mayor | dbo:mayor | dbp:leader |dbo:leader | dbo:leaderName) ?mayor .
?mayor foaf:gender ?gender.
?city dbo:populationTotal ?pop .
?city rdfs:label ?cityName .
?city dbo:country ?ctr .
?city dbo:leaderParty ?party .
?party dbo:ideology ?ideology .
FILTER(str(?gender) = "female")
}
ORDER BY DESC(?pop)
如何编写可在给定节点的任何数据库上运行的通用 SPARQL 查询?
其实很简单:
construct {
?s ?p ?o.
?o ?op ?oo.
?oo ?oop ?ooo.
?ooo ?ooop ?oooo.
?oooo ?oooop ?ooooo.
}
where {
bind(city:_London as ?s)
?s ?p ?o.
optional {
?o ?op ?oo.
optional {
?oo ?oop ?ooo.
optional {
?ooo ?ooop ?oooo.
optional {
?oooo ?oooop ?ooooo.
}
}
}
}
}
构造语句将返回来自相关城市的所有出站链接的图表,并且任何时候返回 null 时,都不会构造该三元组。