正则表达式 SPARQL 查询
Regex SPARQL query
这是我的 SPARQL 查询:
String queryString =
"SELECT ?URI "
+ "WHERE{ ?URI ?predicate ?object ."
+ "FILTER regex(?URI, \"p\", \"i\")}";
Query query = QueryFactory.create(queryString);
QueryExecution qexec = QueryExecutionFactory.create(query, model);
try
{
ResultSet results = qexec.execSelect();
while(results.hasNext()) {
QuerySolution soln = results.nextSolution();
Resource z = (Resource) soln.getResource("URI");
System.out.println(z.toString());
}
finally {
qexec.close();
}
如您所见,我想要 select 包含字母 P 的 URI 资源。
我使用正则表达式过滤器,但我没有得到任何输出,甚至没有空指针异常。
当您对 URI 进行模式匹配时,由于它不是文字,因此您需要使用 str
将其转换为字符串。
一种过滤方法是使用 contains
:
Select ?uri
where {?uri ?p?o.
filter (contains(str(?uri), "p"))
}
或者您可以使用正则表达式:
Select ?uri
where {?uri ?p?o.
FILTER regex(str(?uri), "p", "i")}
}
这是我的 SPARQL 查询:
String queryString =
"SELECT ?URI "
+ "WHERE{ ?URI ?predicate ?object ."
+ "FILTER regex(?URI, \"p\", \"i\")}";
Query query = QueryFactory.create(queryString);
QueryExecution qexec = QueryExecutionFactory.create(query, model);
try
{
ResultSet results = qexec.execSelect();
while(results.hasNext()) {
QuerySolution soln = results.nextSolution();
Resource z = (Resource) soln.getResource("URI");
System.out.println(z.toString());
}
finally {
qexec.close();
}
如您所见,我想要 select 包含字母 P 的 URI 资源。 我使用正则表达式过滤器,但我没有得到任何输出,甚至没有空指针异常。
当您对 URI 进行模式匹配时,由于它不是文字,因此您需要使用 str
将其转换为字符串。
一种过滤方法是使用 contains
:
Select ?uri
where {?uri ?p?o.
filter (contains(str(?uri), "p"))
}
或者您可以使用正则表达式:
Select ?uri
where {?uri ?p?o.
FILTER regex(str(?uri), "p", "i")}
}