- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我想在 SPARQL 中询问一些不同的属性 A 和 B,其中有一个唯一的 A,并且可能有几个 B 属于每个 A。
我得到的查询结果在表单上:
A1, B1
A1, B2
A1, B3
A1, B4
A2, B5
我希望这个查询结果看起来更像是以下形式:
A1: B1,B2,B3,B4
A2: B5
有没有办法在 SPARQL 中做到这一点?这叫什么?
最佳答案
SPARQL 的 JSON 输出记录在 SPARQL 1.1 Query Results JSON Format 中。 ,特别是 3.2.2 Encoding RDF Terms 部分描述了如何在 JSON 中编码 RDF。请注意,JSON 输出实际上只是用于对 SPARQL 查询的结果进行编码,而不是用于创建对应于特定对象模型的 JSON 对象。您最好的选择可能是获取您获得的结果并自己操纵它们。不过,从 SPARQL 方面来说,仍有一些事情可能会有所帮助。
group_concat
用于组合值也就是说,也许以下内容可以帮助您获得对您更有效的东西。如果你有这样的数据:
@prefix : <http://example.org/> .
:object :hasA1 :b1, :b2, :b3, :b4 ;
:hasA2 :b5 .
还有这样的查询:
prefix : <http://example.org/>
select ?subject ?property ?object
where {
values ?property { :hasA1 :hasA2 }
?subject ?property ?object .
}
你会得到如下结果:
$ arq --data data.n3 --query query.sparql
-------------------------------
| subject | property | object |
===============================
| :object | :hasA1 | :b4 |
| :object | :hasA1 | :b3 |
| :object | :hasA1 | :b2 |
| :object | :hasA1 | :b1 |
| :object | :hasA2 | :b5 |
-------------------------------
您可以使用 group_concat
将 hasA1
的所有值组合成一个值,查询如下:
prefix : <http://example.org/>
select ?subject ?property (group_concat(?object;separator=',') as ?cobject)
where {
values ?property { :hasA1 :hasA2 }
?subject ?property ?object .
}
group by ?subject ?property
并得到如下结果:
$ arq --data data.n3 --query query.sparql
------------------------------------------------------------------------------------------------------------------
| subject | property | cobject |
==================================================================================================================
| :object | :hasA2 | "http://example.org/b5" |
| :object | :hasA1 | "http://example.org/b4,http://example.org/b3,http://example.org/b2,http://example.org/b1" |
------------------------------------------------------------------------------------------------------------------
如果您要求 JSON 格式的结果,您将获得以下输出,可能适合您,具体取决于您的 b1
的实体类型—— b4
是。具体来说,如果它们是字符串,连接是有意义的,这可能没问题。如果它们是别的东西,它可能就没那么有用了。
$ arq -out JSON --data data.n3 --query query.sparql
{
"head": {
"vars": [ "subject" , "property" , "cobject" ]
} ,
"results": {
"bindings": [
{
"subject": { "type": "uri" , "value": "http://example.org/object" } ,
"property": { "type": "uri" , "value": "http://example.org/hasA2" } ,
"cobject": { "type": "literal" , "value": "http://example.org/b5" }
} ,
{
"subject": { "type": "uri" , "value": "http://example.org/object" } ,
"property": { "type": "uri" , "value": "http://example.org/hasA1" } ,
"cobject": { "type": "literal" , "value": "http://example.org/b4,http://example.org/b3,http://example.org/b2,http://example.org/b1" }
}
]
}
}
group_concat
和 construct
有 RDF 的 JSON 序列化,虽然 SPARQL 引擎可能不支持它们,但您可以使用 construct
查询来生成一些结构更像您想要的形式的 RDF,并且然后使用 RDF 序列化转换器转换为 JSON 格式。例如,Jena 的 rdfcat
支持 RDF/JSON输出。像这样使用 construct
查询:
prefix : <http://example.org/>
construct {
?subject ?property ?cobject
}
where {
select ?subject ?property (group_concat(?object;separator=',') as ?cobject)
where {
values ?property { :hasA1 :hasA2 }
?subject ?property ?object .
}
group by ?subject ?property
}
(请参阅 answers.semanticweb.com 上的 Can we combine CONSTRUCT with aggregates in SPARQL 1.1?,了解为什么此查询中有嵌套查询。)这会生成以下形式的 RDF:
$ arq --out RDF/XML --data data.n3 --query query.sparql
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns="http://example.org/">
<rdf:Description rdf:about="http://example.org/object">
<hasA1>http://example.org/b4,http://example.org/b3,http://example.org/b2,http://example.org/b1</hasA1>
<hasA2>http://example.org/b5</hasA2>
</rdf:Description>
</rdf:RDF>
我们可以通过 rdfcat
管道来获取一些 RDF/JSON,这最终可能更接近您正在寻找的内容:
$ arq --out RDF/XML --data data.n3 --query query.sparql | rdfcat -out RDF/JSON /dev/stdin
{
"http://example.org/object" : {
"http://example.org/hasA2" : [ {
"type" : "literal" ,
"value" : "http://example.org/b5"
}
] ,
"http://example.org/hasA1" : [ {
"type" : "literal" ,
"value" : "http://example.org/b4,http://example.org/b3,http://example.org/b2,http://example.org/b1"
}
]
}
}
关于json - 从 sparql 查询返回面向对象的 json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18404342/
我正在使用 SPARQL,我想知道是否可以在 in 子句中放入 sparql?更具体地说,我需要获取对此 sparql 查询具有特定条件的实体(s1,s2)[s1 在某个字段上的聚合值大于 5] se
我们有办法在 SPARQL 中做一个不减少的累加和吗? 例如, SELECT ?p WHERE { VALUES ?p { 1 1 2 } } ORDER BY ?p 将导致 1 2 4, - 而
在这个小片段中,第二行的 a 是做什么的? CONSTRUCT { ?uri a skos:Concept ; skos:prefLabel ?prefLabel ; 我确
我写了一个 Sparql 查询。 PREFIX table: SELECT ?name ?color FROM WHERE { ?element table:group ?group. ?gro
下面的两个查询有什么区别吗? select distinct ?i where{ ?i rdf:type . FILTER EXISTS { ?i ?b.
我不太明白为什么在SPARQL中他们没有实现基本的逻辑运算符。然而,在大多数情况下,可以通过多种方式获得相同的结果。 这个问题的目的是快速引用可以替代“or”语句的可能方式。 这是我能想到的: 1)联
我的问题很简单:我有一个源my:g1,其中包含: my:a1 my:b "literal 1" 然后我有第二个源my:g2,其中包含: my:a2 my:b my:c. my:c rdfs:label
我在处理数字数据类型时遇到 SPARQL 问题。 我有一个本体 ( http://cabas.ugr.es/ontology/ugr ),我在其中定义了一对属性,表示特定性别的学生人数:
我有以下 SPARQL 查询: PREFIX rdfs: PREFIX type: PREFIX prop: SELECT * WHERE { ?person a foaf:Per
我想知道如何在sparql中表达以下问题: “请告诉我每个 child 都上麻省理工学院的 parent ” 更一般地说,我想知道查询 sparql 的限制是什么?请问数据库中有哪些类型的答案不能
我正在尝试编写一个优雅的 SPARQL,为多个可能的查询提供一个解决方案。我有多个主语和多个谓词,我想接收一个对象。单一解决方案的存在非常不确定,因此我给出了多种选择。如果我没记错的话,这可以通过以下
这是一个关于 Sparql 和 Wikidata 的问题。我想制定一个返回实例类型关系的查询,但如果它不可用,则返回其子类。我尝试过: SELECT DISTINCT ?ent_type WHER
我想做一些类似的事情 { SELECT ?page, "A" AS ?type WHERE { ?s rdfs:label "Microsoft"@en;
我正在尝试进行 SPARQL 查询,该查询返回一个变量,其中包含两个单词,由某些内容分隔。实际上,我尝试获取一个变量,如 ?πληθυσμός_population(希腊语和英语)。但是,我更喜欢与“
我想知道 SPARQL 默认情况下是否采用开放世界假设,或者这是否取决于执行 SPARQL 查询的三元组存储。 这个假设在查询中的含义是什么。 致以诚挚的问候。 最佳答案 嗯.... 我想知道这对于这
我在处理数字数据类型时遇到 SPARQL 问题。 我有一个本体 ( http://cabas.ugr.es/ontology/ugr ),我在其中定义了一对属性,表示特定性别的学生人数:
我正在玩DBPedia . 通过这个查询,我得到了所有出生在伦敦的人: SELECT ?person WHERE { ?person dbo:birthPlace :London } 但
我需要处理 SPARQL 查询。有没有人有很好的链接来学习 SPARQL 查询?我正在寻找有关 SPARQL 查询和示例语法的好文章,以便我可以快速学习。 最佳答案 Lee Feigenbaum 的
我有一个 SPARQL 查询,它在 Virtuoso SPARQL 查询编辑器中运行时提供结果,但相同的查询在 SPARQL 查询验证器中给出语法错误。问题是什么?为什么显示语法错误? PREFIX
我正在运行 sparql 查询 PREFIX rdfs: PREFIX rdfs: SELECT DISTINCT(?film_link) ?film_name ?wiki
我是一名优秀的程序员,十分优秀!