この例では、LIMITとOFFSETを使用するSPARQL問合せを示します。この例は、次のように表明されるトリプルを挿入します。
JohnはMaryの親である。
JohnはJackの親である。
MaryはJillの親である。
次に、1つの親子関係(LIMIT 1)を検索し、検出された最初の2つの親子関係(OFFSET 2)はスキップして、オプションで見つかった親子に対する孫(gkid)関係を追加します。
import com.hp.hpl.jena.graph.*; import com.hp.hpl.jena.query.*; import com.hp.hpl.jena.rdf.model.Model; import oracle.rdf.kv.client.jena.*; public class Example10 { public static void main(String[] args) throws Exception { String szStoreName = args[0]; String szHostName = args[1]; String szHostPort = args[2]; String szModelName = args[3]; // Create Oracle NoSQL connection OracleNoSqlConnection conn = OracleNoSqlConnection.createInstance(szStoreName, szHostName, szHostPort); // Create model from named graph Model model = OracleModelNoSql.createOracleModelNoSql(szModelName, conn); OracleGraphNoSql graph = (OracleGraphNoSql) model.getGraph(); // Clear graph graph.clearRepository(); // Add triples graph.add(Triple.create(Node.createURI("u:John"), Node.createURI("u:parentOf"), Node.createURI("u:Mary"))); graph.add(Triple.create(Node.createURI("u:John"), Node.createURI("u:parentOf"), Node.createURI("u:Jack"))); graph.add(Triple.create(Node.createURI("u:Mary"), Node.createURI("u:parentOf"), Node.createURI("u:Jill"))); String szQuery = " SELECT ?s ?o ?gkid " + " WHERE { ?s <u:parentOf> ?o . " + " OPTIONAL {?o <u:parentOf> ?gkid }} " + " LIMIT 1 OFFSET 2"; System.out.println("Execute query " + szQuery); Query query = QueryFactory.create(szQuery); QueryExecution qexec = QueryExecutionFactory.create(query, model); try { ResultSet results = qexec.execSelect(); ResultSetFormatter.out(System.out, results, query); } finally { qexec.close(); } model.close(); conn.dispose(); } }
この例をコンパイルして実行するコマンドと、想定されるJavaコマンドの出力は次のとおりです。
javac -classpath ./:./jena-core-2.7.4.jar:./jena-arq-2.9.4.jar: \ ./sdordfnosqlclient.jar:./kvclient.jar:./xercesImpl-2.10.0.jar: \ ./slf4j-api-1.6.4.jar:./slf4j-log4j12-1.6.4.jar:./log4j/1.2.16.jar: \ ./jena-iri-0.9.4.jar:./xml-apis-1.4.01.jar Example10.java javac -classpath ./:./jena-core-2.7.4.jar:./jena-arq-2.9.4.jar: \ ./sdordfnosqlclient.jar:./kvclient.jar:./xercesImpl-2.10.0.jar: \ ./slf4j-api-1.6.4.jar:./slf4j-log4j12-1.6.4.jar:./log4j/1.2.16.jar: \ ./jena-iri-0.9.4.jar:./xml-apis-1.4.01.jar Example10 <store_name> \ <host_name> <host_port> <graph_name> Execute query SELECT ?s ?o ?gkid WHERE { ?s <u:parentOf> ?o . OPTIONAL {?o <u:parentOf> ?gkid }} LIMIT 1 OFFSET 2\ ---------------------------------- | s | o | gkid | ================================== | <u:John> | <u:Mary> | <u:Jill> | ----------------------------------