优化带有标签的许多结果的 WikiData 查询

问题描述

我目前有以下查询

SELECT disTINCT ?location ?place_eng ?admin_eng ?country_eng WHERE {
  {
    ?settlement wdt:P279 wd:Q486972.
    ?place wdt:P31 ?settlement.
    ?place wdt:P1082 ?population.
    FILTER(?population > 400)
    OPTIONAL { ?place wdt:P625 ?location. }
    OPTIONAL { ?place wdt:P131 ?admin. }
    OPTIONAL { ?place wdt:P17 ?country. }
  }

  SERVICE wikibase:label {
    bd:serviceParam wikibase:language "en".
    ?place rdfs:label ?place_eng.
  }
  SERVICE wikibase:label {
    bd:serviceParam wikibase:language "en".
    ?admin rdfs:label ?admin_eng.
  }
  SERVICE wikibase:label {
    bd:serviceParam wikibase:language "en".
    ?country rdfs:label ?country_eng.
  }
}

如您所见,我需要人口超过 400 的人类住区,以及它们的坐标、一级管理、国家和名称,全部为英文。如果我不包括标签查询运行良好,但如果我这样做,它会超时。我还需要一堆其他语言的标签,所以这显然不理想。

我对 SPARQL 比较陌生。你能帮我优化一下这个查询,让它运行吗?

此外,由于我打算稍后将结果与从类似的单独查询中获得的标签连接起来,我该怎么做?假设我现在只获取没有标签的数据,我该如何编写一个查询来为我已有的数据获取标签(我愿意让脚本来完成查询工作)?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...