【Sesame】查詢與修改資料

來源:互聯網
上載者:User

Sesame資料庫利用Java API查詢資料與修改資料。

1. 查詢資料擷取查詢資料(通過SPARQL)
public static void testQuery() {try {   RepositoryConnection con = repo.getConnection();   try {  String queryString = "PREFIX rk:<http://rk.com/test/> " +  "SELECT ?s ?o " +  "WHERE { " +  "?s rk:type rk:CreativeWork ." +  "?s ?p ?o ." +  "} ";  TupleQuery tupleQuery = con.prepareTupleQuery(QueryLanguage.SPARQL, queryString);  long startTime = System.currentTimeMillis();  TupleQueryResult result = tupleQuery.evaluate();  long secondTime = System.currentTimeMillis();    List<String> bindingNames = result.getBindingNames(); //get the name of binded variables  while (result.hasNext()) {     BindingSet bindingSet = result.next();     Value firstValue = bindingSet.getValue("s"); //bindingSet.getValue(bindingNames.get(0));     Value secondValue = bindingSet.getValue("o"); //bindingSet.getValue(bindingNames.get(1));     System.out.println(firstValue);     System.out.println(secondValue);     // do something interesting with the values here...  }  long endTime = System.currentTimeMillis();  System.out.println("evaluation time = "+(secondTime-startTime));  System.out.println("fetch time = "+(endTime-secondTime));   }   finally {      con.close();   }}catch (OpenRDFException e) {    // handle exceptione.printStackTrace();}}

2. 修改資料
public static void updateQuery() {String updateQuery = "PREFIX rk:<http://rk.com/test/> " +"DELETE { " +"?creativeWork rk:type ?type ." +"} " +"INSERT { " +"?creativeWork rk:type ?typeUri ." +"} " +"WHERE { " +"?creativeWork rk:type ?type ." +"BIND( URI(?type) AS ?typeUri ) " +"} ";RepositoryConnection conn;try {conn = repo.getConnection();Update update = conn.prepareUpdate(QueryLanguage.SPARQL, updateQuery);update.execute();conn.commit();conn.close();} catch (RepositoryException e) {e.printStackTrace();} catch (MalformedQueryException e) {e.printStackTrace();} catch (UpdateExecutionException e) {e.printStackTrace();}}

具體SPARQL語言可以參考書籍《Learning SPARQL》。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.