Heim  >  Artikel  >  Datenbank  >  【Sesame】查询与修改数据

【Sesame】查询与修改数据

WBOY
WBOYOriginal
2016-06-07 15:28:371357Durchsuche

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

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 exception
				e.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》。
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:搭建cassandra单数据中心集群(笔记)Nächster Artikel:常见RAC故障