- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在为我的数据库进行 SPARQL 查询时遇到了一些问题。
类( Material 组)中有个人( Material )。每种 Material 都有一些特性,如密度、抗拉强度等,但并非所有 Material 都有。
我需要进行查询,在其中输入每个属性的范围值,如果 Material 具有该属性,将我的值范围与 Material 的值范围进行比较。
我用子查询做到了这一点,因为每个属性都可以有更多的值,由空白节点链接,但它不起作用。
我想要这样的结果:
Material |属性标签 |最小值 |最大值
垫01 |抗拉强度 | 250 | 250
垫02 |抗拉强度 | 255 | 280
垫01 |密度 | 4800 | 4900
垫02 |密度 | 5000 | 5010
我的查询是这样的:
SELECT DISTINCT ?material ?propertyLabel ?minValue ?maxValue WHERE {
?material rdf:type/rdfs:subClassOf* res:Material . #Get all materials
{ OPTIONAL {
SELECT ?material ?propertyLabel (MIN(?value) AS ?minValue) (MAX(?value) AS ?maxValue) WHERE {
?material pro:hasDensity [ unit:hasValue ?value ; unit:hasUnit ?unit ] .
pro:hasDensity rdfs:label ?propertyLabel .
} GROUP BY ?material ?propertyLabel
HAVING ((MAX(?value) > 4500) && (MIN(?value) < 10000))
} }
{ OPTIONAL {
SELECT ?material ?propertyLabel (MIN(?value) AS ?minValue) (MAX(?value) AS ?maxValue) WHERE {
?material pro:hasUltimateTensileStrength [ unit:hasValue ?value ; unit:hasUnit ?unit ] .
pro:hasUltimateTensileStrength rdfs:label ?propertyLabel .
} GROUP BY ?material ?propertyLabel
HAVING ((MAX(?value) > 50) && (MIN(?value) < 300))
} }
# Other properties...
}
附加信息
好的,这里有更清晰的代码和说明...
是的,这个带有 VALUES 的答案现在有效,但是......
它输出的 Material 甚至对一个属性和那个属性都有值(value),但我需要的是满足他们拥有的所有属性的 Material 。
假设我们有 Material :
res:m1
res:m2
res:m3
和 Material 属性:
pro:hasYieldStrenght
pro:hasMeltingPoint
Pro:hasDensity
属性通过空白节点链接到它们的值和单位(对于一个范围)。
Material 1 有一些属性 1,该属性可以有多个值(1、2、3.. 这就是我使用 MIN 和 MAX 的原因),如下所示:
res:m1 pro:hasYieldStrength
[ unit:hasValue "100"^^xsd:double ; unit:hasUnit unit:MegaPascal ] ,
[ unit:hasValue "133"^^xsd:double ; unit:hasUnit unit:MegaPascal ] ;
有些 Material 没有某些属性(它们在现实世界中是未知的,或者它们不在数据库中)。
现在,我想要搜索 Material 的方式是假设我想要所有 Material :pro:hasDensity 2000 - 3000pro:hasMeltingPoint 250 - 400
所以我需要我的搜索值和数据库中特定属性的最小值和最大值的范围交集。
这就是为什么我有:
HAVING ((MAX(?value) > ?low) && (MIN(?value) < ?high))
如果我在输入上只设置一个属性,所有这些都有效。
但是当我想搜索多个交叉点(属性)时,结果包含每种 Material 的属性,因此,假设 Material 仅满足其中一个属性,则该属性和 Material 将在结果中。
结果,我需要的是满足所有属性如果他们拥有的 Material 。
如果 Material 对某些属性没有值(value)(假设没有人测量它)并且满足所有其他属性,则应在该属性上有或没有空值的结果中考虑它,但如果 Material 甚至不能满足一个属性,则不应在结果中考虑它,不仅是针对该属性,而且一般而言,该 Material 。
这就是为什么我在考虑 OPTIONAL,但我已经放弃了它,因为我花了两天时间发现了那个带有值的 bug:p
这是新代码:
SELECT ?m ?p (MAX(?value) AS ?maxValue) (MIN(?value) AS ?minValue) WHERE {
VALUES (?p ?low ?high)
{
( pro:hasDensity 1 300 )
( pro:hasYieldStrength 30 300 )
( pro:hasMeltingPoint 100 350 )
}
?m ?p [ unit:hasValue ?value ; unit:hasUnit ?unit ]
} GROUP BY ?m ?p ?low ?high
HAVING ((MAX(?value) > ?low) && (MIN(?value) < ?high))
好像它甚至没有考虑密度,因为它们都没有这么低的密度,这是结果:
m p maxValue minValue
#m74653522 #hasYieldStrength 110.0 100.0
#m36767231 #hasYieldStrength 262.0 220.0
#Phosphorus #hasMeltingPoint 317.0 317.0
另一方面,有些 Material 具有那么低的密度,但由于其他属性不满足,因此不考虑它们。 (好像这是我不知道的第一行属性的问题..)
最佳答案
在没有看到您的数据的情况下,很难确切地说出问题所在,但听起来您的数据类似于以下内容,其中每种 Material 的几个属性都有多个值。在这种情况下,两种 Material m1 和 m2 分别具有多个属性 p1 和 p2(其中也有标签):
@prefix : <urn:ex:>
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>
:p1 rdfs:label "P one" .
:p2 rdfs:label "P two" .
:m1 :p1 10, 12, 14, 16 ;
:p2 90, 100, 110, 120 .
:m2 :p1 11, 13, 15, 17 ;
:p2 95, 105, 115, 125 .
听起来你想为每个属性指定下限和上限,然后为每个属性和一对界限,检索每个实例的界限内的属性的所有值,并记录最大和最小值每种 Material 的属性。以下查询通过在 values block 中指定属性和边界来实现。 (如果您不熟悉值 block ,请参阅附录。)结果如下。
prefix : <urn:ex:>
prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>
select ?material
?pLabel
(min(?value) as ?min)
(max(?value) as ?max)
where {
values (?p ?lowerBound ?upperBound) {
(:p1 12 15)
(:p2 97 116)
}
?material ?p ?value .
?p rdfs:label ?pLabel .
filter ( ?lowerBound <= ?value && ?value <= ?upperBound )
}
group by ?material ?pLabel
order by ?pLabel ?material
----------------------------------
| material | pLabel | min | max |
==================================
| :m1 | "P one" | 12 | 14 |
| :m2 | "P one" | 13 | 15 |
| :m1 | "P two" | 100 | 110 |
| :m2 | "P two" | 105 | 115 |
----------------------------------
在 SPARQL 1.1 中,值 block 允许您替换,例如,
{ ?s :p1 :o1 }
union
{ ?s :p2 :o2 }
与
values (?p ?o) {
(:p1 :o1)
(:p2 :o2)
}
?s ?p ?o
这是使用联合而不是值的等效查询:
prefix : <urn:ex:>
prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>
select ?material
?pLabel
(min(?value) as ?min)
(max(?value) as ?max)
where {
{
?material :p1 ?value .
:p1 rdfs:label ?pLabel .
filter ( 12 <= ?value && ?value <= 15 )
}
union
{
?material :p2 ?value .
:p2 rdfs:label ?pLabel .
filter ( 97 <= ?value && ?value <= 116 )
}
}
group by ?material ?pLabel
order by ?pLabel ?material
关于rdf - SPARQL 查询。可选子查询和具有 MIN MAX 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26740682/
我正在尝试模拟 Max-Min 和 Min-Min 调度算法,并在模拟中自己编写代码。但是不太了解如何在代码中实现它们的工作方式。 例如,在 FCFS 算法中我使用了 3 个服务器 (vms),每个服
有人可以帮我实现这个功能吗?此功能位于相机应用程序内部,该应用程序使用过滤算法来检测颜色变化等方面的差异。语法对我来说非常困难。我不知道如何处理参数中的指针、最小和最大变量语法、什么是增量等?有人可以
我遇到如图所示的表数据情况,我想从每个唯一成员中选择 min(code) 和 secondary_min(code) 。 即期望的输出看起来像 member | min(code) | s
我有一个查询,选择每小时的最小值: SELECT MIN(price), HOUR(timestamp), DATE(timestamp) FROM `scan` GROUP BY DATE(time
#include int min(int pArray[], int nrOfArrayElements) { min = pArray[0]; for (int i = 1; i
generate(vec.begin(), vec.end(), [=](){return static_cast(static_cast(ran()) /RAND_MAX*(max-min)+min
当 min 已经被定义为宏时,如何调用 std::min? 最佳答案 (std::min)(x,y) min 周围的括号防止宏扩展。这适用于所有函数宏。 关于c++ - 当 min 被定义为宏时如何调
我正在尝试对(几个)SQL 数据库中的现有数据负载进行一些转换分析。 数据结构本身非常简单。它只是一个 Actor 列表(比如 user_id)和他们所做的事情的名称。它看起来像这样(还有其他数据,但
我正在尝试根据浏览器的最小高度和最小宽度更改我页面上的 CSS,所以我正在使用它: @media (min-height: 500px), (min-width: 580px) { /* CSS
我有两张 table 。第一个表显示 id_product 和 Product_price_value。下面我将向您展示一个示例(在我的数据库中有很多行) 表:主产品 ID_product: prod
我有两个表:商品和价格(一对多) 每个项目都有一个默认价格,但是这个价格可以在第二个表中被覆盖(在某些情况下)。 首先,我在获取所有项目并预先计算最低价格 - 默认价格与其覆盖当前价格(如果有的话?)
我使用以下命令用 pandas 读取了此 Excel 工作表(仅“DATEHEUREMAX”列): xdata = read_excel('Data.xlsx', 'Data', usecols=['
我想了解min-max堆删除的过程是如何工作的,我已经搜索了它的伪代码但一无所获,而且我似乎不能在这里询问伪代码。所以这是我的问题 谁能展示“删除最小元素 7”的逻辑,至少让我知道伪代码“感觉如何”?
将 std::min 传递给函数不会编译。我将 std::min 的 libcpp 声明复制到我的源文件中并且它有效。 std 版本有什么问题? clang 和 gcc 也是如此。在 Godbolt
请看这个例子:http://jsfiddle.net/vrgT3/5/ 我用 overflow: auto; 创建了一个 250x250px 父 div,因此当内容溢出框时会出现滚动条。我设置了蓝色背
假设我有 4 个变量 a、b、x、y和一个约束 min(a,b) > min(x,y)。 我如何在 pulp python 中表示这个程序? 最佳答案 好的。所以,我发布(删除)的第一个答案有点仓促,
我刚刚经历了 THIS fiddle 和代码如下所示: 现在,当我使用 View 框并将值更改为 viewbox="100 100 225 225" 时它具有执行以下操作的效果
我有 minSdkVersion 16,我想搜索正确的支持库以便使用方法 setActionBar()(在 api 级别 21 中引入)。 我应该使用哪个 appcompat 版本?当然,我不想使用旧
bootstrap.min.css 和 bootstrap.min.js 有什么区别?为什么需要包含 bootstrap.min.js? 和 最佳答案 它们都是完整 Bootstrap 样式 (C
我是一名优秀的程序员,十分优秀!