SPARQL if-then-else 语句

时间:2021-07-19 09:00:23

标签: if-statement sparql

我正在尝试创建一个 RDF 图,其中: 如果 ?n1 存在,则将创建以下形式的三元组:<?x ex:n "1">。 否则,将创建 <?x ex:n "0"> 形式的三元组。 我的代码如下:

CONSTRUCT {?x ex:n ?result .}

WHERE { 
  ?x ex:n ?n1 .
  BIND (IF(?n1 ="    *"^^xsd:string, "0", "1") AS ?result)
}

但是,只创建值 ?n1 存在的三元组 (<?x ex:n "1">)。 我想念形式的三元组:<?x ex:n "0">。 为什么会这样?

1 个答案:

答案 0 :(得分:2)

" *"^^xsd:string 不会检查您的字符串是否为空。相反,它的字面意思是“四个空格后跟一个星号”。

要检查字符串是否与模式匹配,您应该使用 SPARQL REGEX 函数。因此,您可能需要使用 REGEX(?n1, "^ *$"),其中 ^$ 分别匹配模式的开始和结束,而 * 是零个或多个量词。

CONSTRUCT { ?x ex:n ?result . }
WHERE { 
  ?x ex:n ?n1 .
  BIND (IF(REGEX(?n1, "^ *$"), "0", "1") AS ?result)
}

EDIT:如果您还想检索没有 ?x 但有 <?x ex:n ?n1><?id ex:p ?x> 的值,您可以执行以下操作:

CONSTRUCT { ?x ex:n ?result . }
WHERE { 
  { ?id ex:p ?x . } UNION { ?x ex:n ?n1 . }
  BIND (IF(!BOUND(?n1) || REGEX(?n1, "^ *$"), "0", "1") AS ?result)
}