初始化
sessionPool = new SessionPool("127.0.0.1",6667,"root","root",3,10000,3000,false);
3指的是maxSize
10000 指的是fetchSize fetchSize说明
3000 指的是timeout
false 是 enableCompression
插入
sessionPool.insertRecord(deviceId,i,measurements,types,values);
其他跟session处理一样
查询
使用SessionPool进行查询时,得到的SessionDataSetWrapper,其实用还是用的是sessionDataSet,只不过加上session一起封装了
注意
结果集没有遍历完,或者便利结果集过程出现异常,需要手动调用释放连接的操作closeResultSet()
@Override
public void run() {
SessionDataSetWrapper wrapper = null;
try {
wrapper = pool.executeQueryStatement("select * from root.sestest.wf01.wt01");
for (String columnName : wrapper.getColumnNames()) {
System.out.printf("%-35s",columnName );
}
while (wrapper.hasNext()) {
System.out.println(wrapper.next()+"___"+ this.name);
}
} catch (IoTDBConnectionException | StatementExecutionException e) {
//捕获超时异常
logger.error(e.getMessage(),e);
} finally {
pool.closeResultSet(wrapper);
}
}
看源码:如果等待时间超过一分钟,日志打印警告。如果等待时间超过timeout,抛出异常。我先前timeout设置了3000,其实小于一分钟都没用,还是会等待一分钟。