- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
现在我有一个查询,它返回特定实体的各种属性列表:
SELECT ?propLabel ?val WHERE {
BIND(wd:Q122426 as ?entity)
{
BIND(?entity AS ?valUrl)
BIND("n/a" AS ?propUrl)
BIND("name"@en AS ?propLabel)
?entity rdfs:label ?val.
FILTER((LANG(?val)) = "en")
# instance of
} UNION {
?entity wdt:P31 ?valUrl .
BIND("instance of"@en AS ?propLabel)
# filter isIRI(?valUrl)
?valUrl rdfs:label ?valLabel
FILTER (LANG(?valLabel) = "en")
BIND(CONCAT(?valLabel) AS ?val)
# occupation
} UNION {
?entity wdt:P106 ?val.
BIND("occupation"@en AS ?propLabel)
# position held
} UNION {
?entity wdt:P39 ?val.
BIND("position"@en AS ?propLabel)
# ... and more ...
}
}
# occupation
} UNION {
?entity wdt:P106 ?valUrl.
BIND("occupation"@en AS ?propLabel)
?valUrl rdfs:label ?valLabel
FILTER (LANG(?valLabel) = "en")
BIND(CONCAT(?valLabel) AS ?val)
| ?property | ?valueLabel |
|-------------+-------------|
| tags | politician, Giza East Field, something else, something else |
| name | Henutsen |
UNION
更有效的方式来构造查询?每个谓词?比如,只提供一个谓词列表
P31, P106, P39
等等
最佳答案
这是一个替代 UNION
的版本带小巧VALUES
条款,以及 label service 的使用(在评论中由 AKSW 提供):
SELECT ?entity ?property ?valueLabel {
VALUES ?entity { wd:Q122426 }
VALUES (?p ?property) {
(wdt:P31 "instance of"@en)
(rdfs:label "name"@en)
(wdt:P106 "occupation"@en)
(wdt:P39 "position"@en)
}
?entity ?p ?value
FILTER (!isLiteral(?value) || lang(?value) = "" || langmatches(lang(?value), "en"))
SERVICE wikibase:label { bd:serviceParam wikibase:language "en" }
}
| ?property | ?valueLabel |
|-------------+-------------|
| instance of | human |
| occupation | politician |
| name | Henutsen |
SELECT ?entity
(group_concat(?property; separator=", ") AS ?properties)
(group_concat(?valueLabel; separator=", ") AS ?values)
WHERE {
...
}
GROUP BY ?entity
...
.这个想法是使用
GROUP BY
按实体对结果进行分组(这里不是绝对必要的,因为无论如何我们只有一个实体,但如果您想向查询添加更多实体),然后
group_concat
将每个实体的所有值合并为一个值。
?properties
看起来不错,但
?values
是空的。它可能与“魔术”标签服务有关,可能与聚合不兼容。
SELECT ?property ?valueLabel {
{
SELECT
("tags" AS ?property)
(group_concat(?valueLabel; separator=", ") AS ?valueLabel)
WHERE {
VALUES ?p { wdt:P31 wdt:P106 wdt:P119 wdt:P39 }
wd:Q122426 ?p ?value
SERVICE wikibase:label { bd:serviceParam wikibase:language "en" }
}
} UNION {
BIND ("name"@en AS ?property)
wd:Q122426 rdfs:label ?valueLabel
FILTER langMatches(lang(?valueLabel), "en")
}
}
| ?property | ?valueLabel |
|-----------+------------------------------------|
| tags | human, politician, Giza East Field |
| name | Henutsen |
?valueLabel
标签服务分配了一个值,但随后在
SELECT
中重新分配了一个不同的值内部子查询的子句。这种重新赋值在 SPARQL 中通常是不允许的,但这里实际上需要它来使查询工作。这似乎是标签服务的一个怪癖。
关于SPARQL:将多个谓词值组合成标签数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56192204/
我正在使用 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
我是一名优秀的程序员,十分优秀!