I am sure what I want to do is very easy, yet I cannot seem to get the query right. I have records in dataset which have values such as city name e.g. ‘New York’ and it’s corresponding country code e.g ‘US’. I also have access to the full country name and country ISO codes.
I would like to get the population and abstract value’s for these cities off dbpedia, by using a where clause such as:
Get population where name = "New York" and isoCountryCode = "US"
I’ve searched for help on this to no avail.
so far I have been kindly helped by @rohk with this query, which does not fully work for all locations:
SELECT DISTINCT ?city ?abstract ?pop
WHERE {
?city rdf:type schema:City ;
rdfs:label ?label ;
dbpedia-owl:abstract ?abstract ;
dbpedia-owl:country ?country ;
dbpedia-owl:populationTotal ?pop .
?country dbpprop:countryCode "USA"@en .
FILTER ( lang(?abstract) = 'en' and regex(?label, "New York City"))
}
The above works for New York, however when I change it to:
SELECT DISTINCT ?city ?abstract ?pop
WHERE {
?city rdf:type schema:City ;
rdfs:label ?label ;
dbpedia-owl:abstract ?abstract ;
dbpedia-owl:country ?country ;
dbpedia-owl:populationTotal ?pop .
?country dbpprop:countryCode "THA"@en .
FILTER ( lang(?abstract) = 'en' and regex(?label, "Bangkok"))
}
It returns no results for Bangkok, Thailand.
I just cant seem to get the SPARQL query correct, I’m sure I am being silly with my query. If any guru’s could provide me with help I’d appreciate it. Thanks!
This query is working
EDIT : For Bangkok, there are 2 problems :
rdfs:label "Thailand"@eninstead.rdf:typeof Bangkok is notschema:Citybutdbpedia-owl:SettlementHere is a working query for Bangkok