3

我的问题很简单:我有一个my:g1包含:

my:a1 my:b "literal 1"

然后我有第二个来源my:g2,其中包含:

my:a2 my:b my:c.
my:c rdfs:label "literal 2"

我怎样才能设置一个 SPARQL 查询来产生类似的东西:

| ?a    | ?b    | ?literal    |
|-------|-------|-------------|
| my:a1 | my:b  | "literal 1" |
| my:a2 | my:b  | "literal 2" |

IE。我怎么能告诉 sparql 使用相同的变量"literal 1""literal 2":我正在寻找类似的东西

Select ?a ?b ?literal 
where {
 if (?g = my:g1) then
  GRAPH ?g { ?a ?b ?literal}
 else if (?g = my:g2) then
  GRAPH ?g { ?a ?b ?c. ?c rdfs:label ?literal}
}

注意:我知道这个查询是非常错误的,但只是为了澄清我的意图

编辑:

在这种特定情况下,“联合”声明如

select ?a ?b ?literal 
where {
{
 GRAPH my:g1 { ?a ?b ?literal}
}
union
{
  GRAPH my:g2 { ?a ?b ?c. ?c rdfs:label ?literal}
}
}

会工作,但不是我的“真实”案例。还有其他解决方案吗?

4

1 回答 1

2

您可以使用属性路径和过滤器。这里的技巧是,带问号的属性路径表示长度为 0 或 1 的路径。如果路径的长度为 0,则 ?literal 与 ?c 相同,涵盖了 ?a 直接与字面意思。如果路径长度为 1,则 ?literal 是 ?c 的 rdfs:label 的值。

下面是一个真实数据的例子:

@prefix : <urn:ex:>

:a :b "literal 1" .
:a :b :c .
:c :label "literal 2" .prefix : <urn:ex:>
select distinct ?a ?b ?literal where {
  ?a ?b ?c .
  ?c :label? ?literal
  filter isLiteral(?literal)
}
-----------------------------
| a  | b      | literal     |
=============================
| :a | :b     | "literal 1" |
| :a | :b     | "literal 2" |
| :c | :label | "literal 2" |
-----------------------------

您可能没有预料到结果中的最后一行,但如果 ?a 和 ?b 是变量,那么这是有道理的,因为没有什么说变量?b必须绑定到特定属性:b

于 2015-05-15T13:57:17.873 回答