我正在尝试构建一个可以具有多个可选字段的联合查询。如果任何可选字段没有相应的语句,则结果在该字段上应为空值。只是正常的可选行为:) 但是,如果您使用Wikidata Query Service运行以下代码,即使其他(可选)字段存在相应的语句,结果集也将为空。
如果删除可选的?Pmemberof 字段(该主题没有任何语句),则一切正常,其他语句均返回,这也是我期望的结果原始查询。
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX owl: <http://www.w3.org/2002/07/owl#>
PREFIX wdt: <http://www.wikidata.org/prop/direct/>
PREFIX xsd: <http://www.w3.org/2001/XMLSchema#>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
PREFIX foaf: <http://xmlns.com/foaf/0.1/>
PREFIX bif: <bif:>
SELECT DISTINCT ?wd ?label ?description ?birthname ?placeofbirth ?placeofdeath (GROUP_CONCAT(DISTINCT ?occupation ; separator=', ') AS ?occupations) (GROUP_CONCAT(DISTINCT ?employer ; separator=', ') AS ?employers) (GROUP_CONCAT(DISTINCT ?memberof ; separator=', ') AS ?memberofs)
WHERE
{ SERVICE <http://dbpedia.org/sparql>
{ ?dbp rdf:type foaf:Person ;
rdfs:label ?l ;
owl:sameAs ?wd .
?l bif:contains "Niki AND Lauda"
FILTER strstarts(xsd:string(?wd), "http://www.wikidata.org/entity/")
}
OPTIONAL
{ ?wd <http://schema.org/description> ?description ;
wdt:P1477 ?Pbirthname ;
wdt:P19 ?Pplaceofbirth ;
wdt:P20 ?Pplaceofdeath ;
wdt:P106 ?Poccupation ;
wdt:P108 ?Pemployer ;
wdt:P463 ?Pmemberof # remove this line -> everything works fine
}
FILTER ( lang(?description) = "en" )
SERVICE wikibase:label
{ bd:serviceParam
wikibase:language "[AUTO_LANGUAGE],en" .
?Pdescription
rdfs:label ?description .
?Pbirthname rdfs:label ?birthname .
?Pplaceofbirth
rdfs:label ?placeofbirth .
?Pplaceofdeath
rdfs:label ?placeofdeath .
?Poccupation rdfs:label ?occupation .
?Pemployer rdfs:label ?employer .
?Pmemberof rdfs:label ?memberof .
?wd rdfs:label ?label
}
}
GROUP BY ?wd ?label ?description ?birthname ?placeofbirth ?placeofdeath
LIMIT 1000
我在做什么错?我想返回所有其他语句,即使?Pmemberof 可能没有相应的语句。