0

我正在使用 Jena TDB 存储文件中的三元组数据集。当我尝试使用filter. 例如,以下查询有效:

select ?ob where {
  ?ob rdfs:label "NameOfLabel"@language .
}

但这不是:

select ?ob where {
  ?ob rdfs:label ?pr .
  filter( ?pr = "NameOfLabel" ) .
} 

?ob此查询的目的是从 a中找到一个"NameOfLabel"(忽略语言)。我尝试过regexandstr(?pr)和其他一些东西,但这些都没有奏效。我怎样才能做到这一点?

更新(基于答案)

当我尝试使用filter( str(?pr) = "NameOfLabel" )时,我得到了一个例外。这是堆栈跟踪:

Exception in thread "main" java.lang.IllegalArgumentException: getLow: Empty RecordBuffer
    at com.hp.hpl.jena.tdb.base.buffer.RecordBuffer.getLow(RecordBuffer.java:59)
    at com.hp.hpl.jena.tdb.base.recordbuffer.RecordRangeIterator.hasNext(RecordRangeIterator.java:112)
    at org.apache.jena.atlas.iterator.Iter$4.hasNext(Iter.java:317)
    at com.hp.hpl.jena.tdb.sys.DatasetControlMRSW$IteratorCheckNotConcurrent.hasNext(DatasetControlMRSW.java:119)
    at org.apache.jena.atlas.iterator.Iter$4.hasNext(Iter.java:317)
    at org.apache.jena.atlas.iterator.Iter$3.hasNext(Iter.java:200)
    at org.apache.jena.atlas.iterator.Iter.hasNext(Iter.java:915)
    at org.apache.jena.atlas.iterator.RepeatApplyIterator.hasNext(RepeatApplyIterator.java:59)
    at com.hp.hpl.jena.tdb.solver.SolverLib$IterAbortable.hasNext(SolverLib.java:191)
    at org.apache.jena.atlas.iterator.Iter$4.hasNext(Iter.java:317)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIterPlainWrapper.hasNextBinding(QueryIterPlainWrapper.java:54)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIterConvert.hasNextBinding(QueryIterConvert.java:59)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIterDistinctReduced.hasNextBinding(QueryIterDistinctReduced.java:54)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorWrapper.hasNextBinding(QueryIteratorWrapper.java:40)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorWrapper.hasNextBinding(QueryIteratorWrapper.java:40)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorWrapper.hasNextBinding(QueryIteratorWrapper.java:40)
    at com.hp.hpl.jena.sparql.engine.iterator.QueryIteratorBase.hasNext(QueryIteratorBase.java:112)
    at com.hp.hpl.jena.sparql.engine.ResultSetStream.hasNext(ResultSetStream.java:75)

编辑二:

Dataset dataset = TDBFactory.createDataset(DIRECTORY);
dataset.begin(ReadWrite.READ);

QueryExecution qExec = QueryExecutionFactory.create(query, dataset) ;
ResultSet risultati = qExec.execSelect();
while(risultati.hasNext()){
    system.out.println(risultati.next());
}
4

1 回答 1

4

纯文字“NameOfLabel”带有语言标签“NameOfLabel”@en 的文字不同。如果

?ob rdfs:label "NameOfLabel"@en           # (1)

有效,那么应该

?ob rdfs:label ?label .
filter ( ?label = "NameOfLabel"@en )      # (2)

如果您想在不比较语言的情况下比较过滤器中的字符串内容,只需执行以下操作:

?ob rdfs:label ?label .
filter ( str(?label) = "NameOfLabel" )    # (3)

请注意,(2)确实不是很好的做法。过滤精确值没有多大意义,因为您可以使用 (1) 代替。(3) 没问题,因为您确实需要使用str函数。如果您想在运行时指定一些准确的值,并在查询中有变量,您还可以选择

values ?label { "NameOfObject"@en }
?ob rdfs:label ?label .

它的优点是能够为 ?label 指定多个值。如果您使用的是 Jena,您也可以使用 ParameterizedSparqlString 并且只使用模式

?ob rdfs:label ?label .

但是当你有你想要的值时替换 ?label 。有关ParameterizedSparqlStrings 的示例,请参阅我的答案获取地点 dbpedia 的纬度和经度。

于 2014-07-28T17:24:03.527 回答