Я пытаюсь запросить DBPedia, используя sparql из javacode. Для некоторого запроса он отлично работает и для другого он не работает. Я не думаю, что у меня есть ошибка в моем запросе, потому что я уже тестировал его в конечной точке APPQL DBPedia. Вот мой код Java:
package ja1;
import com.hp.hpl.jena.query.*;
import com.hp.hpl.jena.rdf.model.*;
import com.hp.hpl.jena.util.*;
public class Q_DBP_Online {
public static void main(String[]args)
{
sparqlTest();
}
public static void sparqlTest()
{
/*String queryString = "SELECT ?o WHERE {"+
"?s ?p ?o ."+
"} LIMIT 10";*/
String str="Obama";
String queryString = "PREFIX pr:<http://xmlns.com/foaf/0.1/>" +
"PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>"+
"SELECT DISTINCT ?s ?label WHERE {" +
"?s rdfs:label ?label . "+
"?s a pr:Person."+
"FILTER (lang(?label) = 'en'). "+
"?label bif:contains"+str+" ."+
"}";
Query query = QueryFactory.create(queryString);
QueryExecution qexec = QueryExecutionFactory.sparqlService("http://dbpedia.org/sparql", query);
try
{
ResultSet results = qexec.execSelect();
while(results.hasNext()){
QuerySolution soln = results.nextSolution();
//Literal name = soln.getLiteral("x");
System.out.println(soln);
}
}
finally{
qexec.close();
}
}
}
Таким образом, первый запрос, который комментируется, отлично работает, а второй не запускается, и я получаю это сообщение в netbeans:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/rodwan/Desktop/Th_Pr/apache-jena-2.12.1/lib/slf4j-log4j12-1.7.6.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/rodwan/Desktop/Th_Pr/pellet-2.3.1/lib/jena/slf4j-log4j12-1.6.4.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
Exception in thread "main" com.hp.hpl.jena.query.QueryParseException: Encountered " "(" "( "" at line 1, column 169.
Was expecting one of:
"values" ...
"graph" ...
"optional" ...
"minus" ...
"bind" ...
"service" ...
"filter" ...
"{" ...
"}" ...
";" ...
"," ...
"." ...
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 ja1.Q_DBP_Online.sparqlTest(Q_DBP_Online.java:38)
at ja1.Q_DBP_Online.main(Q_DBP_Online.java:18)
Java Result: 1
BUILD SUCCESSFUL (total time: 1 second)
----------------------------------
Я попробовал ваш пример, но кажется, что есть некоторые пробелы. Для DBPedia для меня работало следующее:
PREFIX pr:<http://xmlns.com/foaf/0.1/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT DISTINCT ?s ?label WHERE {?s rdfs:label ?label . ?s a pr:Person . FILTER (lang(?label) = 'en') . ?label bif:contains "Obama" .}
Перевод на Java будет выглядеть так:
String queryString = "PREFIX pr:<http://xmlns.com/foaf/0.1/>\n" +
"PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>\n"+
"SELECT DISTINCT ?s ?label WHERE {" + "?s rdfs:label ?label . "+
"?s a pr:Person . "+
"FILTER (lang(?label) = 'en') . "+
"?label bif:contains \""+str+"\" ."+
"}";
Надеюсь это поможет.
Проблема в том, что синтаксический анализатор запросов строго проверяет, все ли вы использовали префикс, объявленный в начале запроса, и это явно не относится к bif:contains
- это фактически встроенное свойство Virtuoso.
Вы уже предоставили одно решение с использованием угловых скобок, т.е. <bif:contains>
.
Другим способом было бы использовать класс QueryEngineHttp с помощью чего-то вроде
QueryEngineHttp qe = new QueryEngineHttp(queryString);
и просто отправьте строку запроса в конечную точку, а не разбирайте ее в объект запроса раньше.