2

假设我在 db 中有金属材料,其屈服强度可以从 300 到 500 MPa。我怎样才能输入它作为文字值。

我应该放置 2 个属性,例如YieldStrengthMinand YieldStrengthMax,还是可以在单个条目中完成并格式化为 300 - 500 之类的东西。我知道我可以把它作为字符串类型,但我需要的是当我 SPARQL 我的数据库时,我应该进行查询,以找到所有可以说的材料YieldStrength > 350。如果它在那个区间甚至​​是部分的,它应该是一个有效的结果。

好的,另一个例子来澄清

我将拥有材料数据库,每种材料都有许多属性。比方说prop:hasMeltingTemperature

material:ZA-12 prop:hasMeltingTemperature    "380 - 430".

material:Zn    prop:hasMeltingTemperature    "420".

其中一些(清洁材料)将具有一个熔化温度,合金的温度将根据某些成分的百分比而变化。

我的应用程序必须从 db 中获取所有材料,假设熔化温度 > 400。所以在这种情况下,它应该同时获取它们。

如果我询问我需要所有熔化温度 < 425 的材料,它也应该同时使用它们。如果查询 < 400,则只有第一个材料。

无论如何,我的问题是:

我应该做这样的属性:

material:ZA-12 prop:hasMeltingTemperature_MIN "380".

material:ZA-12 prop:hasMeltingTemperature_MAX "430".

material:Zn    prop:hasMeltingTemperature     "420".

然后当我查询时,我必须检测“>”,然后将其与“MIN”温度和“solo”温度进行比较,如果是“<”,则将其与“MAX”温度和“solo”温度进行比较。

在这种情况下,我必须首先检测材料是否只有“一个”或“最小-最大”温度或“无”温度属性。

或者

我可以像第一个示例中那样做,并且只有一个属性,例如:

material:ZA-12 prop:hasMeltingTemperature "380 - 430".

material:Zn    prop:hasMeltingTemperature "420" .

并进行某种可以理解“间隔”并比较它们的sparql查询?

这就是我想知道的,因为材料有很多属性,很多材料,其中一些具有“最小最大值”值,一些“单独”值,有些根本没有那个属性,但是有另一个同样的问题...

我的应用程序将在 php 中,所以我将不得不在 php 中生成 sparql 查询,这就是为什么我正在寻找一些“通用”类型的查询(只检查一个属性)..

所以我的问题更多是如何有效地查询 sparql,存储数据的 2 有什么更好的选择,以及如何查询它

4

1 回答 1

7

这里有几个不同的意思。你可以

  1. 声明属性的范围是某个范围内的值;
  2. 断言对于某个特定的个体,其特定属性的值在某个范围内;

鉴于你说:

我需要的是,当我使用 SPARQL 我的数据库时,我应该进行查询以找到所有材料,让我们说 YieldStrength > 350。如果它在那个区间内,即使是部分的,它也应该是一个有效的结果。

使用两个属性

我认为最好的方法是使用两个属性(例如minStrength/ maxStrength)。这意味着您可以拥有如下数据:

metal72 minStrength 200 ;
        maxStrength 400 .

然后你可以编写一个带有类似模式的查询

?metal minStrength ?min ;
       maxStrength ?max .
filter( ?min <= 350 && 350 <= ?max )

我认为这与您试图捕捉的想法最接近,因为听起来每种金属实际上都与某些值范围相关联。在某些金属可以具有精确值(而不是范围)的情况下,您仍然可以通过输入数据来使用这种方法:

Zn minStrength 420 ;
   maxStrength 420 .

然后你所有的金属都是一致的(它们都有一个最小值和一个最大值),你的查询不必担心不同的情况。

使用范围,并查询 OWL 的 RDF 序列化

现在,虽然我认为以前的方法更有意义,但您可以在 OWL 中表示数据范围。例如,如果有一个hasStrength属性,你可以说某些金属仅在某个范围内具有强度,方法是使用类似的限制

metal72 a (hasStrength only int[>=200,<=400])

在 Protégé 中,这看起来像:

Protege 中的限制

这实际上意味着虽然不是金属具有一定的强度范围,而是对于任何三元形式的形式metal72 hasStrength x, 的值x必须int在范围内[200,400],否则数据不一致。这显然不同于说金属具有强度范围。

OWL 本体可以在 RDF 中序列化,然后您可以使用 SPARQL 查询 RDF。不过,您需要知道 RDF 的样子。在这种情况下,它是:

:metal72  a     owl:NamedIndividual , :Metal ;
        a       [ a                  owl:Restriction ;
                  owl:allValuesFrom  [ a                     rdfs:Datatype ;
                                       owl:onDatatype        xsd:int ;
                                       owl:withRestrictions  ( [ xsd:minInclusive
                                                         200 ] [ xsd:maxInclusive
                                                         400 ] )
                                     ] ;
                  owl:onProperty     :hasStrength
                ] .

这有点多,但您可以使用 SPARQL 使用如下查询对其进行查询。它将返回任何?metal具有 type 的hasStrength only int[>=min,<=max], where min ≤ 350 ≤ max

prefix metal: <http://www.example.org/metal#>
prefix owl:   <http://www.w3.org/2002/07/owl#>
prefix xsd:   <http://www.w3.org/2001/XMLSchema#>
prefix rdf:   <http://www.w3.org/1999/02/22-rdf-syntax-ns#>

select ?metal where { 
  ?metal a metal:Metal ;
         a [ owl:allValuesFrom [ owl:withRestrictions [ rdf:rest* [ xsd:minInclusive ?min ] ] ;
                                                      [ rdf:rest* [ xsd:maxInclusive ?max ] ] ] ;
             owl:onProperty metal:hasStrength ] .
  filter( ?min <= 350 && 350 <= ?max ) 
}
于 2013-11-11T23:51:46.470 回答