如何在SKOS中进行概念搜索?

时间:2015-01-15 07:54:43

标签: rdf skos

我使用SKOS创建了一个本体,它包含两个概念,concept1concept2。我在Temperature Sensor中添加了一个首选标签Temperature@en和三个替代标签Temp@enT@enconcept1

我希望当我向包含TempTTemperature的目标概念发送请求时,SKOS会以相同的概念回复Temperature Sensor(其中在优选标签中定义)。

我怎样才能做到这一点?是否可以使用SKOS实现这一目标? rdf文件的一部分如下所示。

<skos:Concept rdf:about="TemperatureSensor">    
<skos:altLabel xml:lang="en">T</skos:altLabel>    
<skos:altLabel xml:lang="en">Temp</skos:altLabel>    
<skos:altLabel xml:lang="en">Temperature</skos:altLabel>     
<skos:prefLabel xml:lang="en">TemperatureSensor</skos:prefLabel>      
<skos:inScheme rdf:resource="conceptSchemeSensors"/></skos:Concept>

1 个答案:

答案 0 :(得分:1)

您提供的数据尚未完成;它缺少一些前缀声明,它使用相对IRI,但没有定义基本IRI。以下是我们可以使用的完整数据:

<rdf:RDF
    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
    xmlns:skos="http://www.w3.org/2004/02/skos/core#">
  <skos:Concept rdf:about="http://stackoverflow.com/q/27958866/1281433/TemperatureSensor">
    <skos:altLabel xml:lang="en">T</skos:altLabel>
    <skos:altLabel xml:lang="en">Temp</skos:altLabel>
    <skos:altLabel xml:lang="en">Temperature</skos:altLabel>
    <skos:prefLabel xml:lang="en">TemperatureSensor</skos:prefLabel>
    <skos:inScheme rdf:resource="http://stackoverflow.com/q/27958866/1281433/conceptSchemeSensors"/>
  </skos:Concept>
</rdf:RDF>

这是我们可以在同一数据上运行的SPARQL查询。它检索所有概念,它们的首选标签以及它们的替代标签。然后它使用 coalesce 来获取任何首选标签,如果没有这些标签,则为该概念的任何替代标签。

prefix rdf:   <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
prefix skos:  <http://www.w3.org/2004/02/skos/core#>
prefix : <http://stackoverflow.com/q/27958866/1281433/>

select ?concept (coalesce(sample(?prefLabel),sample(?altLabel)) as ?label) where {
  ?concept skos:altLabel ?altLabel ;
           skos:prefLabel ?prefLabel .
}
group by ?concept
-----------------------------------------------
| concept            | label                  |
===============================================
| :TemperatureSensor | "TemperatureSensor"@en |
-----------------------------------------------