IoTDB连接池SessionPool基本使用
初始化
sessionPool = new SessionPool("127.0.0.1",6667,"root","root",3,10000,3000,false);
3指的是maxSize
10000 指的是fetchSize
3000 指的是timeout
false 是 enableCompression
插入
sessionPool.insertRecord(deviceId,i,measurements,types,values);
其他跟处理一样
查询
使用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,其实小于一分钟都没用,还是会等待一分钟。
下一篇:
网上银行系统4:生成实体类和映射文件