我正在使用D2RQ的d2r-query进行一些SPARQL查询,我正在使用命令行。请问,我怎样才能得到响应时间?
d2r-query myMappedData.ttl "SELECT * {?s ?p ?o} LIMIT 1000"是否有其他工具可用于获取响应时间?
发布于 2019-10-20 09:43:37
嗨,我找到了一个解决方案,我想和你分享一下。因此,您应该编辑d2_quey.java文件,获取查询代码处理前后的日期,并计算timeAfterTreatment - timeBeforeTreatment
就像下面的代码:
Object objStartTime=System.currentTimeMillis();
Long startTime=(objStartTime==null)?0:(Long)objStartTime; 此代码之前(处理查询)
QueryEngineD2RQ.register();
Query q = QueryFactory.create(query, loader.getResourceBaseURI());
QueryExecution qe = QueryExecutionFactory.create(q, d2rqModel);
if (timeout > 0) {
qe.setTimeout(Math.round(timeout * 1000));
}
QueryExecUtils.executeQuery(q, qe, ResultsFormat.lookup(format));并在末尾添加以下代码
Object objEndTime=System.currentTimeMillis();
Long endTime=(objEndTime==null)?0:(Long)objEndTime;
Long totalTime = endTime - startTime;
// display response time
System.out.println("============================================");
System.out.println("Response time : "+totalTime+" ms ");
System.out.println("============================================");祝好运
https://stackoverflow.com/questions/58369630
复制相似问题