如何解决SPARQL 在 DBPedia 中查询所有活过 20 世纪的人
我想在 DBPedia 中查询整个 20 世纪的所有人。 我使用 https://dbpedia.org/sparql/ 来处理我的查询。我已将输出限制为 20。
我尝试过的查询如下:
@validates('username')
def validates_username(self,key,value):
if self.username and self.username != value: # Field already exists
raise ValueError('Username cannot be modified.')
return value
在输出中,所有人都在 1999-12-31 之后死亡,但他们不是在 1900-01-01 之前出生的。 为什么我的查询错误?我该如何解决?
提前感谢您抽出宝贵时间。
解决方法
这个问题是由于查询结果中包含整数值,可以使用相同或新的 FILTER() 部分中的 DATATYPE() 函数解决。
例如:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX dbo: <http://dbpedia.org/ontology/>
PREFIX dbp: <http://dbpedia.org/property/>
PREFIX xsd: <http://www.w3.org/2001/XMLSchema#>
SELECT ?personName ?birthDate ?deathDate
WHERE
{
?person rdf:type dbo:Person;
dbp:name ?personName;
dbp:birthDate ?birthDate;
dbp:deathDate ?deathDate.
#This FILTER ensures that only xsd:date values are returned
FILTER(DATATYPE(?birthDate) = xsd:date && DATATYPE(?deathDate) = xsd:date).
FILTER (?birthDate < "1900-01-01"^^xsd:date && ?deathDate > "1999-12-31"^^xsd:date).
}
LIMIT 20
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。