WikiData SPARQL查询失败,要求CONTAINS工作

时间:2017-11-23 08:13:31

标签: sparql wikidata

当我包含使用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) } .
       }
    }  .
}

Try it here

我的问题是为什么第二个选项不起作用?

(是的,我正在寻找外科医生唐纳德特朗普,而不是其他人)

1 个答案:

答案 0 :(得分:1)

维基数据中的标签有语言标签,因此标签文字是

“唐纳德特朗普”@en

LCASE之后的字符串将是

“唐纳德特朗普”@en

确实CONTAINS在这里工作。

您必须使用STR函数来获取词法形式,即只需

“唐纳德特朗普”

解决方案:

FILTER(LCASE(STR(?idLabel)) = "donald trump") .