繁体   English   中英

如何在 SPARQL 中构造列表

[英]How to construct a list in SPARQL

我有一个看起来像这样的ttl文件:

ex:Shape1
    a sh:NodeShape ;
    sh:property ex:Property-1
    rdfs:label "Shape 1"

ex:Property-1
    a sh:PropertyShape ;
    sh:path ex:property1
    sh:in (
        "Option 1"
        "Option 2"
    ) ;
    sh:name "Property 1"

ex:property1
    a owl:DatatypeProperty

将上述数据加载到我的三重存储(已经包含许多形状)后,我可以使用什么查询来检索相同的数据?

这个查询得到我需要的一切,除了列表。 对于列表,它只给出一个空白节点。

PREFIX sh: <http://www.w3.org/ns/shacl#>
PREFIX ex: <http://example.com/#>

CONSTRUCT {
  ?subject ?predicate ?object
}
WHERE {
  {
    bind(ex:Shape1 as ?subject)
    ex:Shape1 ?predicate ?object
  }
  UNION
  {
     ex:Shape1 sh:property ?subject .
    ?subject ?predicate ?object
  }
  UNION
  {
    ex:Shape1 sh:property/sh:path ?subject .
    ?subject ?predicate ?object
  }
}

首先,为什么需要查询才能取回相同的数据? 您的意思是您需要以相同的语法和格式获取它吗?

  • 要以三元组的形式获取相同的数据,您可以简单地执行 SELECT * from ?s ?p ?o 它会给您所有的三元组。 这也取决于您的三联店。

  • 获取列表中项目的标准查询如下:

     PREFIX sh: <http://www.w3.org/ns/shacl#> PREFIX ex: <http://example.com/#> PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> SELECT ?item WHERE { ex:Property-1 sh:in/rdf:rest*/rdf:first ?item }

您可以阅读有关列表项如何在内部存储的更多信息。 这个链接会很有帮助。 您可以在构造查询的 UNION 或 WHERE 子句中以相同的方式绑定 ex:Property-1 以获得所需的结果。

我希望它会有所帮助。 祝你好运。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM