【问题标题】:SPARQL Query ExceptionSPARQL 查询异常
【发布时间】:2013-11-25 00:13:12
【问题描述】:

我正在使用 APACHE JENA(2.9.4 版本)来使用 SPARQL 查询获取结果。以下是我正在使用的代码。

public class DataGeneratorTest {

public static void main(String[] args) {

    String query = "PREFIX rdfs:<http://www.w3.org/2000/01/rdf-schema#> PREFIX owl:<http://dbpedia.org/ontology/> select ?y where { ?x a owl:Person; rdfs:label ?y. FILTER(LANG(?y) = \"en\") } LIMIT 77";
    ResultSet resultSet = SparqlUtil.generate(query);
    ResultSetFormatter.out(System.out, resultSet);

}
}

我有一个用于执行 sparql 查询的实用程序类...

public class SparqlUtil {

public static ResultSet generate(String argEndPoint, String argQuery) {
    Precondition.checkNotEmpty(argQuery);
    String endPoint = argEndPoint;
    if (Precondition.checkEmpty(endPoint)) {
        endPoint = SparqlConstants.SPARQL_ENDPOINT;
    }
    QueryExecution queryExecution = null;
    try {
        Query query = QueryFactory.create(argQuery);
        queryExecution = QueryExecutionFactory.sparqlService(endPoint,
                query);
        return queryExecution.execSelect();
    } finally {
        if (Precondition.checkNotNull(queryExecution)) {
            queryExecution.close();
        }
    }
}

public static ResultSet generate(String argQuery) {
    return generate(SparqlConstants.SPARQL_ENDPOINT, argQuery);
}
}

当我运行此代码时,出现以下异常。

javax.xml.stream.XMLStreamException: ParseError at [row,col]:[40,26]
Message: XML document structures must start and end within the same entity.
at com.sun.org.apache.xerces.internal.impl.XMLStreamReaderImpl.next(Unknown Source)
at    com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.getOneSolution(XMLInputStAX.java:435)
at com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.hasNext(XMLInputStAX.java:232)
at com.hp.hpl.jena.sparql.resultset.ResultSetMem.<init>(ResultSetMem.java:95)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:147)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:130)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:118)
at com.hp.hpl.jena.sparql.resultset.TextOutput.format(TextOutput.java:65)
at com.hp.hpl.jena.query.ResultSetFormatter.out(ResultSetFormatter.java:122)
at com.hp.hpl.jena.query.ResultSetFormatter.out(ResultSetFormatter.java:74)
at com.data.generator.test.DataGeneratorTest.main(DataGeneratorTest.java:17)
Exception in thread "main" com.hp.hpl.jena.sparql.resultset.ResultSetException: XMLStreamException:     ParseError at [row,col]:[40,26]
Message: XML document structures must start and end within the same entity.
at com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.staxError(XMLInputStAX.java:539)
at com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.hasNext(XMLInputStAX.java:236)
at com.hp.hpl.jena.sparql.resultset.ResultSetMem.<init>(ResultSetMem.java:95)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:147)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:130)
at com.hp.hpl.jena.sparql.resultset.TextOutput.write(TextOutput.java:118)
at com.hp.hpl.jena.sparql.resultset.TextOutput.format(TextOutput.java:65)
at com.hp.hpl.jena.query.ResultSetFormatter.out(ResultSetFormatter.java:122)
at com.hp.hpl.jena.query.ResultSetFormatter.out(ResultSetFormatter.java:74)
at com.data.generator.test.DataGeneratorTest.main(DataGeneratorTest.java:17)
Caused by: javax.xml.stream.XMLStreamException: ParseError at [row,col]:[40,26]
Message: XML document structures must start and end within the same entity.
at com.sun.org.apache.xerces.internal.impl.XMLStreamReaderImpl.next(Unknown Source)
at     com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.getOneSolution(XMLInputStAX.java:435)
at com.hp.hpl.jena.sparql.resultset.XMLInputStAX$ResultSetStAX.hasNext(XMLInputStAX.java:232)
... 8 more

我正在尝试仅检索前 77 个结果。当我将此结果集限制为 76 时,我能够毫无例外地获取结果,但是当我将此限制增加到 77 时,我得到了上述异常。第 77 条记录有问题。我该如何克服这个问题。我卡在这里。谁能帮我解决这个问题...???

提前谢谢, 阿马尔。

【问题讨论】:

  • 升级总是好的第一步。
  • 嗨,Andy,我已升级到最新的 APACHE JENA (2.11.0) 版本。尽管我面临同样的问题。

标签: sparql dbpedia


【解决方案1】:

什么是 SparqlConstants.SPARQL_ENDPOINT? dbpedia.org 有时间限制并截断结果,导致非法 XML。这可以解释这种情况,但不知道第 77 个条目是什么,如果有的话,我们不能说。

【讨论】:

  • 嗨,安迪,这里 SparqlConstants.SPARQL_ENDPOINT 只不过是 "dbpedia.org/sparql"。我正在使用这个端点来获取结果。同时,我从 WEB UI 测试了这个查询,我得到了所有结果,没有任何例外。我该如何解决这个问题...???
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-05-09
  • 2013-02-17
  • 1970-01-01
相关资源
最近更新 更多