属性函数扩展sparql

时间:2015-11-02 08:56:15

标签: java sparql jena arq

我想用arq jena写一个属性函数扩展sparql,我怎么写? 请求:

SELECT *
WHERE {?Person f:Next(name) ?x.}

我的功能代码:

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.apache.jena.atlas.logging.Log;
import org.apache.jena.graph.Node;
import org.apache.jena.query.QueryBuildException;
import org.apache.jena.query.QueryException;
import org.apache.jena.rdf.model.Model;
import org.apache.jena.rdf.model.ModelFactory;
import org.apache.jena.rdf.model.Property;
import org.apache.jena.rdf.model.RDFNode;
import org.apache.jena.rdf.model.Resource;
import org.apache.jena.rdf.model.Statement;
import org.apache.jena.rdf.model.StmtIterator;
import org.apache.jena.sparql.engine.ExecutionContext;
import org.apache.jena.sparql.engine.QueryIterator;
import org.apache.jena.sparql.engine.binding.Binding;
import org.apache.jena.sparql.engine.iterator.QueryIterNullIterator;
import org.apache.jena.sparql.pfunction.PFuncSimple;
import org.apache.jena.sparql.pfunction.PFuncSimpleAndList;
import org.apache.jena.sparql.pfunction.PropFuncArg;
import org.apache.jena.sparql.pfunction.PropertyFunction;
import org.apache.jena.sparql.pfunction.PropertyFunctionFactory;
import org.apache.jena.sparql.util.IterLib;



public class Next implements PropertyFunctionFactory {
@Override
public PropertyFunction create(final String uri)
{   
    return new PFuncSimple()
    {

        @Override
        public QueryIterator execEvaluated(final Binding parent, final Node        subject, final Node predicate, final Node object, final ExecutionContext execCxt) 
        {   
            Model model = ModelFactory.createDefaultModel();
InputStream is = null;
    try {
        is = new BufferedInputStream(
                new FileInputStream( "C:\\\\fichier rdf/journal.webscience.org-vivo.rdf"));
    } catch (FileNotFoundException ex) {
        Logger.getLogger(haschild.class.getName()).log(Level.SEVERE, null, ex);
    }
 model.read(new InputStreamReader(is), "");
 StmtIterator iter = model.listStatements();

从rdf中提取sebject,谓词和对象:

 for (;iter.hasNext();) {
  Statement stmt      = iter.nextStatement();
Resource  sub   = stmt.getSubject();    
Property  pred = stmt.getPredicate();   
RDFNode   obj    = stmt.getObject();

将rdf的suject和谓词与请求的主语和谓词进行比较

 if ((sub.toString().equals(subject.toString()))||    (pred.toString().equals(predicate.toString())))
           return  new QueryIterPlainWrapper ((Iterator<Binding>) obj,execCxt);
            }
            return null;
        }
    };
}
    }

以及我如何注册我的功能

1 个答案:

答案 0 :(得分:0)

属性函数的语法与常规属性相同。没有特殊的语法。

?Person :somePropertyFunction ?x .

属性函数可以访问三重模式的主题和对象。当主题或对象是RDF列表时,也有帮助。

通常,参数作为对象或对象列表,结果作为主题或主题列表。

您不需要使用.toString

您无法将obj投射到Iterator<Binding>

查看一些现有的属性函数。 splitIRI很简单。 concat可能有用 - 它需要一个参数列表(对象位置)并返回一个主题(变量)。