如何解决如何使用 SPARQL 查询 wikidata 以查找符合特定条件且地理位置靠近另一城市的地点
我编写了以下 SPARQL 查询来查找意大利标签为“San Leucio”的维基数据项。
SELECT disTINCT * WHERE {
?location ?label 'San Leucio'@en .
?location wdt:P17 wd:Q38 .
?location rdfs:label ?locationName .
OPTIONAL {
?article schema:about ?location .
?article schema:isPartOf <https://en.wikivoyage.org/> .
}
?location wdt:P18 ?image .
FILTER(lang(?locationName) = "en")
}
查询返回这 3 个结果:
wd:Q55179410
wd:Q20009063
wd:Q846499
我想要的结果是 wd:Q846499,它位于意大利那不勒斯以外。有什么办法可以进一步过滤这个查询以返回最接近那不勒斯的结果?我知道我可以使用 ?location wdt:P625 ?coordinates
获得每个这些的地理坐标,但我不确定如何使用它与那不勒斯的地理坐标进行比较以获得我想要的。
解决方法
SELECT DISTINCT * {
VALUES ?naples {wd:Q2634}
?Napfes wdt:P625 ?naples_coordinates.
?location rdfs:label 'San Leucio'@en .
?location wdt:P17 wd:Q38 .
?location wdt:P18 ?image .
?location wdt:P625 ?location_coordinates.
OPTIONAL {
?article schema:about ?location .
?article schema:isPartOf <https://en.wikivoyage.org/> .
}
BIND (geof:distance(?location_coordinates,?naples_coordinates) AS ?distance)
} ORDER BY ?distance LIMIT 1
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。