正则表达式 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")}
}