0
import java.sql.ResultSet;
import java.sql.SQLException;
import com.hp.hpl.jena.query.QueryExecution;
import com.hp.hpl.jena.query.QueryExecutionFactory;
import com.hp.hpl.jena.query.QueryFactory;
import com.hp.hpl.jena.query.QuerySolution;
import com.hp.hpl.jena.query.ResultSetFormatter;

public class sparq {
    public static void main (String[] args) throws SQLException
{

    String queryString=
            "PREFIX dbpedia: <http://dbpedia.org/resource/>"+
            "PREFIX category: <http://dbpedia.org/resource/Category:>"+
            "PREFIX skos: <http://www.w3.org/2004/02/skos/core#>"+
            "PREFIX dcterms: <http://purl.org/dc/terms/>"+
            "select distinct ?super where {"+
                  "?super (^skos:broader){0,4} category:Nationalist_parties, category:New_Delhi"+
                "}";



            // now creating query object

            com.hp.hpl.jena.query.Query query = QueryFactory.create(queryString);
            // initializing queryExecution factory with remote service.
            // **this actually was the main problem I couldn't figure out.**
            QueryExecution qexec = QueryExecutionFactory.sparqlService("http://dbpedia.org/sparql", query);


            //after it goes standard query execution and result processing which can
            // be found in almost any Jena/SPARQL tutorial.
            try {
                com.hp.hpl.jena.query.ResultSet results = qexec.execSelect();
                while(results.hasNext())
                {
                    QuerySolution s=results.nextSolution();
                    String strg=s.getResource("?x").toString();
                    System.out.println(strg);
                }
                //ResultSetFormatter.out(System.out, results, query);  
            }
            finally {
               qexec.close();
            }

}
}

Eclipse-Apache Jena を使用して上記のクエリを実行すると、次のエラーが発生します。しかし、dbpedia sparql virtuso の Web サービス ページで同じクエリを実行すると、望ましい結果が得られます。

log4j:WARN No appenders could be found for logger (org.apache.jena.riot.system.stream.JenaIOEnvironment).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Exception in thread "main" com.hp.hpl.jena.query.QueryParseException: Encountered " "{" "{ "" at line 1, column 249.
Was expecting one of:
    <IRIref> ...
    <PNAME_NS> ...
    <PNAME_LN> ...
    <BLANK_NODE_LABEL> ...
    <VAR1> ...
    <VAR2> ...
    "true" ...
    "false" ...
    <INTEGER> ...
    <DECIMAL> ...
    <DOUBLE> ...
    <INTEGER_POSITIVE> ...
    <DECIMAL_POSITIVE> ...
    <DOUBLE_POSITIVE> ...
    <INTEGER_NEGATIVE> ...
    <DECIMAL_NEGATIVE> ...
    <DOUBLE_NEGATIVE> ...
    <STRING_LITERAL1> ...
    <STRING_LITERAL2> ...
    <STRING_LITERAL_LONG1> ...
    <STRING_LITERAL_LONG2> ...
    "(" ...
    <NIL> ...
    "[" ...
    <ANON> ...
    "+" ...
    "*" ...
    "/" ...
    "|" ...
    "?" ...

    at com.hp.hpl.jena.sparql.lang.ParserSPARQL11.perform(ParserSPARQL11.java:102)
    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 sparq.main(sparq.java:49)

しかし、Web上でDBPedia Virtuso sparqlを使用して同じクエリを実行すると、結果が得られます。 私はApche jenaが初めてです助けてください!!!!

4

2 に答える 2

0

私は問題の解決策を次のように見つけました

void std_query()
    {
        String query = "select distinct ?super where {?super (^skos:broader){0,3} category:Nationalist_parties, category:New_Delhi}";
        QueryEngineHTTP qe = new QueryEngineHTTP("http://dbpedia.org/sparql", query);

        try {
            com.hp.hpl.jena.query.ResultSet results = qe.execSelect();
            while(results.hasNext())
            {
                QuerySolution s=results.nextSolution();
                String strg=s.getResource("?super").toString();
                System.out.println("########### Standard Sparql Result #########");
                System.out.println(strg);
            }
            //ResultSetFormatter.out(System.out, results, query);  
        }
        finally {
           qe.close();
        }
    }
于 2015-03-10T05:15:27.187 に答える
0

Virtuoso は非標準の構文を受け入れます。{n,m}構文は、プロパティ パスの以前の提案の1 つに含まれていましたが、SPARQL 1.1 標準には受け入れられませんでした。その結果、クエリは実際には合法的な SPARQL 1.1 (または SPARQL 1.0) ではありません。sparql.org の query validatorを使用して、クエリが合法かどうかを確認できます。

Jena の API を使用して、最初にクエリを検証しないように要求することもできると思います。その場合、クエリを送信できます。たとえば、次のコメントを参照してください。

Jena を使用して Virtuoso 固有の機能を使用してクエリを送信する場合は、QueryEngineHTTP (QueryExecution) を直接作成し、エンドポイントとクエリ文字列の 2 つの文字列のみを提供する必要があります。それ以外の場合、Jena はクエリをローカルで検証しますが、有効な SPARQL ではないため失敗します。— AndyS 24 9 月. 142014-09-24 10:48:00

または、このanswers.semanticweb.comの質問: jenaは、正しいが非標準の SPARQL で QueryParsingException をスローします。その質問で、OP は次のようなコードで QueryEngineHTTP を直接作成することで解決策を見つけました。

QueryEngineHTTP qe = new QueryEngineHTTP("http://dbpedia.org/sparq","select ...");
ResultSet rs = qe.execSelect();
于 2015-03-09T13:42:28.863 に答える