SPARQL arbitrary-length 属性 具有任意但定向属性的路径查询
SPARQL arbitrary-length property path query with arbitrary but directed properties
假设我有以下 RDF 图:
@prefix : <http://example/> .
:order1 :item :z1 .
:order2 :item :z2 .
:z1 :name "Small" .
:z1 :price 5 .
:z2 :name "Large" .
:z2 :price 5 .
我想要一个 SPARQL 查询 select 所有描述 :z1 的三元组。即所有三元组 children 或 children of children (etc.) of :z1。到目前为止,我发现这被称为具有任意属性的 arbitrary-length 属性 路径。我使用了 SPARQL property path queries with arbitrary properties and Sparql - query to get all triples related to a specific subject 的解决方案来提出这个查询:
PREFIX : <http://example/>
SELECT ?s ?p ?o
WHERE {
?s ?p ?o .
:order1 (<>|!<>)+ ?o . # Match arbitrary-length property path with arbitrary properties
}
这导致(以 ttl 格式):
@prefix : <http://example/> .
:order1 :item :z1 .
:z2 :price 5 .
:z1 :name "Small" ;
:price 5 .
如您所见,这也是 select 的 :z2 :price 5 .
三元组,这是我没想到的,也不是我想要的。出于某种原因,似乎还包括从 object 5 到主题 :z2 的反向 :price
路径推断。
如何实现 selecting 包含在 :z1 的 arbitrary-length 属性 路径中的具有任意 但定向 属性的所有三元组?
注意:这是我尝试解决的真实问题的简化版本,其中路径中的谓词和路径的长度确实可以是任意的。
也许这张图有帮助:
如@UninformedUser 所述,我从 :order1
开始获取所有 传入 边,而我想要所有 输出 边.
正确的查询是:
PREFIX : <http://example/>
SELECT ?s ?p ?o
WHERE {
?s ?p ?o .
:order1 (<>|!<>)* ?s . # Match arbitrary-length property path with arbitrary properties
}
我在 :order1 (<>|!<>)+ ?o .
中将 ?o
更改为 ?s
所以我只匹配出边,即主题 (?s
) 是目标的路径上的三元组'mother' 三元组。
我还在 :order1 (<>|!<>)+ ?o .
中将 +
更改为 *
所以我匹配长度为 0 或更多而不是 1 或更多的路径所以我也得到了三元组 :order1
是主语。
假设我有以下 RDF 图:
@prefix : <http://example/> .
:order1 :item :z1 .
:order2 :item :z2 .
:z1 :name "Small" .
:z1 :price 5 .
:z2 :name "Large" .
:z2 :price 5 .
我想要一个 SPARQL 查询 select 所有描述 :z1 的三元组。即所有三元组 children 或 children of children (etc.) of :z1。到目前为止,我发现这被称为具有任意属性的 arbitrary-length 属性 路径。我使用了 SPARQL property path queries with arbitrary properties and Sparql - query to get all triples related to a specific subject 的解决方案来提出这个查询:
PREFIX : <http://example/>
SELECT ?s ?p ?o
WHERE {
?s ?p ?o .
:order1 (<>|!<>)+ ?o . # Match arbitrary-length property path with arbitrary properties
}
这导致(以 ttl 格式):
@prefix : <http://example/> .
:order1 :item :z1 .
:z2 :price 5 .
:z1 :name "Small" ;
:price 5 .
如您所见,这也是 select 的 :z2 :price 5 .
三元组,这是我没想到的,也不是我想要的。出于某种原因,似乎还包括从 object 5 到主题 :z2 的反向 :price
路径推断。
如何实现 selecting 包含在 :z1 的 arbitrary-length 属性 路径中的具有任意 但定向 属性的所有三元组?
注意:这是我尝试解决的真实问题的简化版本,其中路径中的谓词和路径的长度确实可以是任意的。
也许这张图有帮助:
如@UninformedUser 所述,我从 :order1
开始获取所有 传入 边,而我想要所有 输出 边.
正确的查询是:
PREFIX : <http://example/>
SELECT ?s ?p ?o
WHERE {
?s ?p ?o .
:order1 (<>|!<>)* ?s . # Match arbitrary-length property path with arbitrary properties
}
我在 :order1 (<>|!<>)+ ?o .
中将 ?o
更改为 ?s
所以我只匹配出边,即主题 (?s
) 是目标的路径上的三元组'mother' 三元组。
我还在 :order1 (<>|!<>)+ ?o .
中将 +
更改为 *
所以我匹配长度为 0 或更多而不是 1 或更多的路径所以我也得到了三元组 :order1
是主语。