IoTDB连接池SessionPool基本使用

初始化

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值