如何编写 SPARQL 查询以从 OWL 文件中检索数据
How to write a SPARQL query for retrieving data from OWL file
我使用 Protege 生成了一个 owl 文件。现在,我希望从中访问 stationCode 属性 所有 class RailwayStation 实例的值。
我的 OWL 文件包含以下格式
<?xml version="1.0"?>
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:swrlb="http://www.w3.org/2003/11/swrlb#"
xmlns:xsp="http://www.owl-ontologies.com/2005/08/07/xsp.owl#"
xmlns:owl="http://www.w3.org/2002/07/owl#"
xmlns:protege="http://protege.stanford.edu/plugins/owl/protege#"
xmlns:swrl="http://www.w3.org/2003/11/swrl#"
xmlns:swrla="http://swrl.stanford.edu/ontologies/3.3/swrla.owl#"
xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
xmlns:sqwrl="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl#"
xmlns="http://www.owl-ontologies.com/RailwaysSemantic.owl#"
xmlns:xsd="http://www.w3.org/2001/XMLSchema#"
xml:base="http://www.owl-ontologies.com/RailwaysSemantic.owl">
<owl:Ontology rdf:about="">
<owl:imports rdf:resource="http://swrl.stanford.edu/ontologies/3.3/swrla.owl"/>
<owl:imports rdf:resource="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl"/>
</owl:Ontology>
<rdfs:Class rdf:ID="BusStand"/>
<rdfs:Class rdf:ID="Eatery"/>
<rdfs:Class rdf:ID="Train"/>
<rdfs:Class rdf:ID="Hospital"/>
<rdfs:Class rdf:ID="City"/>
<rdfs:Class rdf:ID="RailwayStation"/>
<rdfs:Class rdf:ID="Airport"/>
<rdfs:Class rdf:ID="TouristSpot"/>
<rdfs:Class rdf:ID="Schedule"/>
<RailwayStation rdf:ID="RailwayStation_YPR">
<stationCode rdf:datatype="http://www.w3.org/2001/XMLSchema#string">
YPR</stationCode>
</RailwayStation>
如何为此目的编写 SPARQL 查询?
我当前的查询是这样的:
String querystr = "PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>"+
"PREFIX owl:<http://www.w3.org/2002/07/owl#>"+
"PREFIX rdfs:<http://www.w3.org/2000/01/rdf-schema#>"+
"SELECT * WHERE {"+
"?RailwayStation stationCode ?x ."+
"}";
但是它给出了这样的异常:
Exception in thread "main" com.hp.hpl.jena.query.QueryParseException: Lexical error at line 1, column 194. Encountered: " " (32), after : "stationCode"
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.perform(ParserSPARQL11.java:111)
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.parse$(ParserSPARQL11.java:53)
at com.hp.hpl.jena.sparql.lang.SPARQLParser.parse(SPARQLParser.java:37)
at com.hp.hpl.jena.query.QueryFactory.parse(QueryFactory.java:148)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:80)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:53)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:41)
at org.iiitb.jena.Main.sprqltest(Main.java:70)
at org.iiitb.jena.Main.main(Main.java:22)
"?RailwayStation stationCode ?x ."
属性 必须是 URI(有 <>)或前缀名(有冒号)。
您的文件和查询存在一些问题。首先,您必须知道,当您在 xml/rdf 文件中声明一个 base
命名空间时,所有没有使用特定命名空间的标签都将添加到您的基本命名空间 http://www.owl-ontologies.com/RailwaysSemantic.owl
中。但在你的情况下,我认为 Protege 为你生成了这个命名空间。关于您的文件,将 # or /
添加到基本命名空间的末尾。
最后,对于您的查询:添加前缀 PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
就像您对 rdf 和 rdfs 所做的那样...
在此之后,您希望访问 class RailwayStation 所有实例的所有 stationCode 属性 值,回答此问题的 sparql 查询是:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s a <http://www.owl-ontologies.com/RailwaysSemantic.owl#RailwayStation> .
?s <http://www.owl-ontologies.com/RailwaysSemantic.owl#stationCode> ?o}
我在您的文件中对其进行了测试,returns 结果不错。我故意没有在我的查询中使用命名空间,因此您可以立即在数据中测试它而无需更改命名空间;)
祝你好运
我们可以通过使用前缀使其更具可读性,如下所示:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s base:RailwayStation .
?s base:stationCode ?o}
我使用 Protege 生成了一个 owl 文件。现在,我希望从中访问 stationCode 属性 所有 class RailwayStation 实例的值。
我的 OWL 文件包含以下格式
<?xml version="1.0"?>
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:swrlb="http://www.w3.org/2003/11/swrlb#"
xmlns:xsp="http://www.owl-ontologies.com/2005/08/07/xsp.owl#"
xmlns:owl="http://www.w3.org/2002/07/owl#"
xmlns:protege="http://protege.stanford.edu/plugins/owl/protege#"
xmlns:swrl="http://www.w3.org/2003/11/swrl#"
xmlns:swrla="http://swrl.stanford.edu/ontologies/3.3/swrla.owl#"
xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
xmlns:sqwrl="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl#"
xmlns="http://www.owl-ontologies.com/RailwaysSemantic.owl#"
xmlns:xsd="http://www.w3.org/2001/XMLSchema#"
xml:base="http://www.owl-ontologies.com/RailwaysSemantic.owl">
<owl:Ontology rdf:about="">
<owl:imports rdf:resource="http://swrl.stanford.edu/ontologies/3.3/swrla.owl"/>
<owl:imports rdf:resource="http://sqwrl.stanford.edu/ontologies/built-ins/3.4/sqwrl.owl"/>
</owl:Ontology>
<rdfs:Class rdf:ID="BusStand"/>
<rdfs:Class rdf:ID="Eatery"/>
<rdfs:Class rdf:ID="Train"/>
<rdfs:Class rdf:ID="Hospital"/>
<rdfs:Class rdf:ID="City"/>
<rdfs:Class rdf:ID="RailwayStation"/>
<rdfs:Class rdf:ID="Airport"/>
<rdfs:Class rdf:ID="TouristSpot"/>
<rdfs:Class rdf:ID="Schedule"/>
<RailwayStation rdf:ID="RailwayStation_YPR">
<stationCode rdf:datatype="http://www.w3.org/2001/XMLSchema#string">
YPR</stationCode>
</RailwayStation>
如何为此目的编写 SPARQL 查询?
我当前的查询是这样的:
String querystr = "PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>"+
"PREFIX owl:<http://www.w3.org/2002/07/owl#>"+
"PREFIX rdfs:<http://www.w3.org/2000/01/rdf-schema#>"+
"SELECT * WHERE {"+
"?RailwayStation stationCode ?x ."+
"}";
但是它给出了这样的异常:
Exception in thread "main" com.hp.hpl.jena.query.QueryParseException: Lexical error at line 1, column 194. Encountered: " " (32), after : "stationCode"
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.perform(ParserSPARQL11.java:111)
at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.parse$(ParserSPARQL11.java:53)
at com.hp.hpl.jena.sparql.lang.SPARQLParser.parse(SPARQLParser.java:37)
at com.hp.hpl.jena.query.QueryFactory.parse(QueryFactory.java:148)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:80)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:53)
at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:41)
at org.iiitb.jena.Main.sprqltest(Main.java:70)
at org.iiitb.jena.Main.main(Main.java:22)
"?RailwayStation stationCode ?x ."
属性 必须是 URI(有 <>)或前缀名(有冒号)。
您的文件和查询存在一些问题。首先,您必须知道,当您在 xml/rdf 文件中声明一个 base
命名空间时,所有没有使用特定命名空间的标签都将添加到您的基本命名空间 http://www.owl-ontologies.com/RailwaysSemantic.owl
中。但在你的情况下,我认为 Protege 为你生成了这个命名空间。关于您的文件,将 # or /
添加到基本命名空间的末尾。
最后,对于您的查询:添加前缀 PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
就像您对 rdf 和 rdfs 所做的那样...
在此之后,您希望访问 class RailwayStation 所有实例的所有 stationCode 属性 值,回答此问题的 sparql 查询是:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s a <http://www.owl-ontologies.com/RailwaysSemantic.owl#RailwayStation> .
?s <http://www.owl-ontologies.com/RailwaysSemantic.owl#stationCode> ?o}
我在您的文件中对其进行了测试,returns 结果不错。我故意没有在我的查询中使用命名空间,因此您可以立即在数据中测试它而无需更改命名空间;) 祝你好运
我们可以通过使用前缀使其更具可读性,如下所示:
PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX base: <http://www.owl-ontologies.com/RailwaysSemantic.owl#>
select *
where { ?s base:RailwayStation .
?s base:stationCode ?o}