目次
この項では、主なRDFグラフ機能の例を示します。どの例もそれぞれで完結しており、通例はグラフの作成、トリプルの追加、問合せの実行(推論を含む場合もある)、結果の表示、およびモデルの削除を行います。
これらの説明は、examples/ディレクトリに収録されています。
この項には、次の各操作を行う例があります。
グラフ(または名前付きグラフ)の作成とトリプルの挿入/削除。
推論されたグラフ(または推論された名前付きグラフ)の作成と、グラフに属する推論されたトリプルの挿入/削除。
Oracle NoSQL DatabaseへのRDFファイルのロード。
次のようなファミリ・オントロジを使用した複数のSPARQL問合せの実行。
LIMIT、OFFSET、ASK、DESCRIBE、CONSTRUCTなどのSPARQL問合せ機能。
TIMEOUT、DOP、ORDERED、INF_ONLY、ASSERTED_ONLYなど、RDFグラフ機能の問合せオプション。
PLANなどRDFグラフ機能のヒント。
Apache Jena ARQの組込み関数の使用。
SELECTキャスト問合せ。
Oracle NoSQL Databaseにデータを挿入するSPARQL Updateのリクエスト。
OracleNoSqlConnectionを使用したOracle NoSQL Databaseへの接続の作成。
Oracle NoSQL Database接続プーリングの使用。
指定したグラフまたはデータセットのサンプリング・データの生成。
問合せを実行するには、次の操作を実行する必要があります。
Javaソース・ファイルにコードを含めます。この項で使用されている例は、パッケージのexamplesディレクトリにファイルとして用意されています。
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 Example.java
コンパイルしたファイルを実行します。次に例を示します。
java -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 Example <store_name \ > <host_name> <host_port>
この例では、Oracle NoSQL Databaseに格納されているデフォルトのグラフに対して一連のトリプルを追加/削除する方法について説明します。
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 Example1 {
public static void main(String[] args) throws Exception
{
String szStoreName = args[0];
String szHostName = args[1];
String szHostPort = args[2];
OracleNoSqlConnection conn
= OracleNoSqlConnection.createInstance(szStoreName,
szHostName,
szHostPort);
// This object will handle operations over the default graph
OracleGraphNoSql graph = new OracleGraphNoSql(conn);
graph.clearRepository(); //Clear the graph including inferred triples
graph.add(Triple.create(Node.createURI("u:John"),
Node.createURI("u:parentOf"),
Node.createURI("u:Mary")));
graph.add(Triple.create(Node.createURI("u:Mary"),
Node.createURI("u:parentOf"),
Node.createURI("u:Jack")));
String queryString = " select ?x ?y WHERE {?x <u:parentOf> ?y}";
System.out.println("Execute query " + queryString);
Model model = new OracleModelNoSql(graph);
Query query = QueryFactory.create(queryString);
QueryExecution qexec = QueryExecutionFactory.create(query, model);
try {
ResultSet results = qexec.execSelect();
ResultSetFormatter.out(System.out, results, query);
}
finally {
qexec.close();
}
graph.delete(Triple.create(Node.createURI("u:John"),
Node.createURI("u:parentOf"),
Node.createURI("u:Mary")));
queryString = "select ?x ?y ?z WHERE {?x ?y ?z}";
System.out.println("Execute query " + queryString);
query = QueryFactory.create(queryString) ;
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 Example.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 \
Example1 <store_name> <host_name> <host_port>
Execute query select ?x ?y WHERE {?x <u:parentOf> ?y}
-----------------------
| x | y |
=======================
| <u:Mary> | <u:Jack> |
| <u:John> | <u:Mary> |
-----------------------
Execute query select ?x ?y ?z WHERE {?x ?y ?z}
--------------------------------------
| x | y | z |
======================================
| <u:Mary> | <u:parentOf> | <u:Jack> |
--------------------------------------