当我包含使用CONTAINS作为过滤器的行时,下面的查询有效,但如果我只是检查值(LCASE)是否等于“donald trump”(它是),则会失败。
使用此行,它可以正常工作:
过滤器(包含(LCASE(?idLabel),“唐纳德特朗普”))。
使用此行,它会失败:
过滤器(LCASE(?idLabel)=“唐纳德特朗普”)。
WORKS具有idLabel =“Donald Trump”
的查询的输出SPARQL查询:
SELECT DISTINCT ?id ?idLabel ?PV WHERE {
?id wdt:P106 ?V0. VALUES ?V0 { wd:Q39631 } .
OPTIONAL {
?id rdfs:label ?idLabel .
FILTER(LANG(?idLabel) = 'en') .
} .
# Filter on Label
# WORKS:
FILTER(CONTAINS(LCASE(?idLabel), "donald trump") ).
# DOES NOT WORK
#FILTER(LCASE(?idLabel) = "donald trump") .
# subselect on instance type
{
SELECT ?id WHERE {
?id wdt:P31/wdt:P279* ?PV . VALUES(?PV) {(wd:Q5) } .
}
} .
}
我的问题是为什么第二个选项不起作用?
(是的,我正在寻找外科医生唐纳德特朗普,而不是其他人)
答案 0 :(得分:1)
维基数据中的标签有语言标签,因此标签文字是
“唐纳德特朗普”@en
和LCASE
之后的字符串将是
“唐纳德特朗普”@en
确实CONTAINS
在这里工作。
您必须使用STR
函数来获取词法形式,即只需
解决方案:
FILTER(LCASE(STR(?idLabel)) = "donald trump") .