我想使用tdbloader
或tdbloader2
将数据加载到Fuseki时设置基本网址。目前本地路径用作基础,这不是我想要的。例如:
# mytriple.ttl
@prefix owl: <http://www.w3.org/2002/07/owl#> .
<#myitem> a owl:Thing .
./tdbloader --loc /path/to/database /path/to/local/file/mytriple.ttl
# sparql query example
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX owl: <http://www.w3.org/2002/07/owl#>
SELECT ?subject ?predicate ?object
WHERE {
?subject ?predicate ?object .
?subject a owl:Thing .
}
查询结果:
<file:///path/to/local/file/mytriple.ttl#myitem> rdf:type owl:Thing
这是(1)在数据库中不是很干净,(2)当我想在需要指定基数时查询特定项目时,它会导致可维护性问题:
PREFIX owl: <http://www.w3.org/2002/07/owl#>
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
SELECT ?subject ?predicate ?object
WHERE {
?subject a owl:Thing .
<file:///path/to/local/file/mytriple.ttl#myitem> ?predicate ?object .
}
或
PREFIX owl: <http://www.w3.org/2002/07/owl#>
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
BASE <file:///path/to/local/file/mytriple.ttl>
SELECT ?subject ?predicate ?object
WHERE {
?subject a owl:Thing .
<#myitem> ?predicate ?object .
}
如何在tdbloader
中指定不同的基数,例如<mydomain:myontology#>
?
答案 0 :(得分:1)
在数据中添加BASE
或@base
语句。这样数据就很稳定 - 在任何地方使用它都会提供相同的三元组。
或者为了避免编辑文件:
cat "MyBase.ttl" "MyData.ttl" > D.ttl
tdbloader --loc DB D.ttl