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,其实小于一分钟都没用,还是会等待一分钟。

经验分享 程序员 微信小程序 职场和发展