我为sparql执行编写的代码是否正确?

时间:2011-03-11 04:57:27

标签: java logging sparql jena

我的代码:

package sample;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

import com.hp.hpl.jena.query.Query;
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.ResultSet;
import com.hp.hpl.jena.query.ResultSetFormatter;
import com.hp.hpl.jena.rdf.model.Model;
import com.hp.hpl.jena.rdf.model.ModelFactory;

public class QueryTest {

public static void main(String[] args) throws IOException {
    InputStream in = new FileInputStream(new File("foaf-ijd.rdf"));

    Model model = ModelFactory.createMemModelMaker().createDefaultModel();

    model.read(in, null);
    in.close();

    String queryString = "SELECT ?x WHERE (?x, <http://www.w3.org/2001/vcard-rdf/3.0#FN>, 'John Smith')";

    Query query = QueryFactory.create(queryString);

    QueryExecution qe = QueryExecutionFactory.create(query, model);
    ResultSet results = qe.execSelect();

    ResultSetFormatter.out(System.out, results, query);

    qe.close();

}

}

生成错误

Exception in thread "main" java.lang.NoSuchMethodError: org.slf4j.Logger.trace(Ljava/lang/String;)V
    at com.hp.hpl.jena.sparql.lib.SystemUtils.chooseClassLoader(SystemUtils.java:23)
    at com.hp.hpl.jena.sparql.lib.Metadata.init(Metadata.java:45)
    at com.hp.hpl.jena.sparql.lib.Metadata.get(Metadata.java:75)
    at com.hp.hpl.jena.query.ARQ.<clinit>(ARQ.java:253)
    at com.hp.hpl.jena.query.Query.<clinit>(Query.java:54)
    at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:71)
    at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:43)
    at com.hp.hpl.jena.query.QueryFactory.create(QueryFactory.java:31)
    at sample.QueryTest.main(QueryTest.java:29)

*

2 个答案:

答案 0 :(得分:2)

您的代码看起来没问题,您获得的错误来自Jena使用的其中一个库。您使用的是哪个版本的Jena?你试过最新版本吗?您是否确保Jena下载的.jar目录中的所有lib/都在您的CLASSPATH上?如果是这样,您是否检查过以确保您的CLASSPATH上没有多个冲突版本的Jena(或slf4j-*.jar)?

答案 1 :(得分:1)

SPARQL查询错误,你应该使用'{'代替'('而不是逗号:

    String queryString = "SELECT ?x WHERE { ?x <http://www.w3.org/2001/vcard-rdf/3.0#FN> \"John Smith\"}";