例8.12では、推論のみの設定(INF_ONLY)などの追加機能を使用するSPARQL問合せを示します。この例は、次のように表明されるトリプルを挿入します。
JohnはMaryの親である。
JohnはJackの親である。
AmyはMaryの親である。
JackはMaryと同レベルである(推論済と指定)
次に、Oracle NoSQL Databaseのすべてのトリプルを検索します。RDFグラフ機能パッケージの例5fでは、同じ練習で表明のみの設定(ASSERTED_ONLY)を使用する場合を説明します。例5fはこのマニュアルでは紹介していません。
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 Example5e { public static void main(String[] args) throws Exception { String szStoreName = args[0]; String szHostName = args[1]; String szHostPort = args[2]; int iRuleBaseId = Integer.parseInt(args[3]); // Create Oracle NoSQL connection OracleNoSqlConnection conn = OracleNoSqlConnection.createInstance(szStoreName, szHostName, szHostPort); // Create model from default graph Model model = OracleModelNoSql.createOracleDefaultModelNoSql(conn); OracleGraphNoSql graph = (OracleGraphNoSql) model.getGraph(); // Clear model model.removeAll(); // 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:Amy"), Node.createURI("u:parentOf"), Node.createURI("u:Jack"))); // Create Oracle NoSQL inferred graph InferredGraphNoSql inferredGraph = new InferredGraphNoSql(conn, iRuleBaseId); // Add inferred triples inferredGraph.add(Triple.create(Node.createURI("u:Jack"), Node.createURI("u:siblingOf"), Node.createURI("u:Mary"))); // Close inferred graph; inferredGraph.close(); String prefix = " PREFIX ORACLE_SEM_FS_NS: " + " <http://oracle.com/semtech#" + "include_rulebase_id=" + iRuleBaseId + ",inf_only>"; String szQuery = prefix + " select ?x ?y ?z WHERE {?x ?y ?z} "; 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 Example5e.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 Example5e <store_name> \ <host_name> <host_port> <rule_baseID> Execute query PREFIX ORACLE_SEM_FS_NS: <http://oracle.com/semtech#inf_only> select ?x ?y ?z WHERE {?x ?y ?z} --------------------------------------- | x | y | z | ======================================= | <u:Jack> | <u:siblingOf> | <u:Mary> | ---------------------------------------
表明のみの設定を指定した場合のJavaコマンドで想定される出力は、次のとおりです。
-------------------------------------- | x | y | z | ====================================== | <u:John> | <u:parentOf> | <u:Jack> | | <u:John> | <u:parentOf> | <u:Mary> | | <u:Amy> | <u:parentOf> | <u:Jack> | --------------------------------------