这是我的配置文件
# Licensed under the terms of http://www.apache.org/licenses/LICENSE-2.0
## Fuseki Server configuration file.
@prefix : <#> .
@prefix fuseki: <http://jena.apache.org/fuseki#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix ja: <http://jena.hpl.hp.com/2005/11/Assembler#> .
@prefix tdb: <http://jena.hpl.hp.com/2008/tdb#> .
[] rdf:type fuseki:Server ;
fuseki:services (
<#service1>
)
.
# TDB
tdb:DatasetTDB rdfs:subClassOf ja:RDFDataset .
tdb:GraphTDB rdfs:subClassOf ja:Model .
[] ja:loadClass "com.hp.hpl.jena.tdb.TDB" .
<#service1> rdf:type fuseki:Service ;
fuseki:name "rs" ; # http://host:port/ds
fuseki:serviceQuery "sparql" ; # SPARQL query service
fuseki:serviceQuery "query" ; # SPARQL query service (alt name)
fuseki:serviceUpdate "update" ; # SPARQL update service
fuseki:serviceUpload "upload" ; # Non-SPARQL upload service
fuseki:serviceReadWriteGraphStore "data" ; # SPARQL Graph store protocol (read and write)
# A separate read-only graph store endpoint:
fuseki:serviceReadGraphStore "get" ; # SPARQL Graph store protocol (read only)
fuseki:dataset <#dataset> ;
.
<#dataset> rdf:type tdb:DatasetTDB ;
tdb:location "RS" ;
ja:defaultGraph <#model_inf> ;
.
<#model_inf> a ja:InfModel ;
ja:baseModel <#tdbGraph> ;
ja:reasoner [
ja:reasonerURL <http://jena.hpl.hp.com/2003/OWLFBRuleReasoner>]
.
<#tdbGraph> rdf:type tdb:GraphTDB ;
tdb:dataset <#RSDataSet> .
<#RSDataSet> rdf:type tdb:DatasetTDB ;
tdb:location "RS" ;
tdb:unionDefaultGraph true ;
.
当我运行fuseki (2.3)我可以看到我使用TDB的数据集(不是在记忆中)我可以上传我的rdf三元组,即使我关闭fuseki并重新打开它,三元组在那里,但是反应者没有工作
这是我的数据
@prefix : <http://example.org/rs#>
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>
:A rdfs:subClassOf :B .
:B rdfs:subClassOf :C .
:i a :A .
当我执行此查询时
select * where {
:i a ?e
}
我只得到:A
我应该得到:B
和:C
我的配置有什么不对吗?
答案 0 :(得分:4)
我猜你运行fuseki时可能无法正确加载配置文件。您是否明确要求fuseki使用您的配置文件?
按照本教程中的说明(http://krr.cs.vu.nl/wp-content/uploads/2013/09/protege-fuseki-yasgui-manual.pdf),我的fuseki运行良好,具有推理功能。检查第3页,我希望你能解决问题。
答案 1 :(得分:2)
这一行
<#dataset> rdf:type tdb:DatasetTDB ;
说它是TDB数据库,但并不是所需要的。您需要ja:RDFDataset
来包含使用TDB作为其基本数据的inf图。
(需要测试)
<#dataset> rdf:type ja:RDFDataset ;
ja:defaultGraph <#model_inf> ;
.
答案 2 :(得分:0)
不熟悉Fuseki的细节,我敢打赌你需要在OWL或RDFS配置文件上显式调用推理引擎。一旦完成,你应该看到你想要的蕴涵。 OTOH,有一个常见的SPARQL查询将获得相同的结果:
In [118]: df.groupby('Building ID').filter(lambda x: (x['CorporationName']=='n/a').all())
Out[118]:
Building ID CorporationName IndividualName
3 2 n/a Tim
4 2 n/a Larry
5 2 n/a Paul
6 3 n/a Rachel
或者,使用属性路径更紧凑:
SELECT ?e
WHERE {
:i a ?cls .
?cls rdfs:subClassOf* ?e .
}