IoTDB四种插入方式及分析

本文探讨了四种向物联网数据库插入数据的方法:insertRecord(无类型信息)、insertRecord(带TSDataType)、insertTablet和JDBC。根据性能,作者认为insertTablet最佳,其次是带类型的insertRecord,然后是不带类型的insertRecord,最后是JDBC。在使用insertTablet时,即使设备存在未使用的测量点,如s3,也能插入数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方式一:insertRecord插入没有指定类型

    public static void insert()throws Exception{
        Session session = new Session("127.0.0.1",6667,"root","root");
        session.open();

        String deviceId = "root.sestest.wf01.wt01";
        List<String> measurements = new ArrayList<>(3);
        measurements.add("s0");
        measurements.add("s1");
        measurements.add("s2");


        for(long i = 5000 ;i <6000 ;i++){
            List<String> values = new ArrayList<>(3);
            values.add("5");
            values.add("6");
            values.add("7");

            session.insertRecord(deviceId,i,measurements,values);
        }
        session.close();
    }

 

 

方式二:insertRecord插入的时候带TSDataType

    public static void insert2()throws Exception{
        Session session = new Session("127.0.0.1",6667,"root","root");
        session.open();

        String deviceId = "root.sestest.wf01.wt01";
        List<String> measurements = new ArrayList<>(3);
        measurements.add("s0");
        measurements.add("s1");
        measurements.add("s2");


        for(long i = 1000 ;i <5000 ;i++){
            List<Object> values = new ArrayList<>(3);
            List<TSDataType> types = new ArrayList<>(3);
            values.add(1);
            types.add(TSDataType.INT32);
            values.add(2);
            types.add(TSDataType.INT32);
            values.add(3);
            types.add(TSDataType.INT32);

            session.insertRecord(deviceId,i,measurements,types,values);
        }
        session.close();
    }

 

方式三:insertTablet

    public static void insert3()throws Exception{
        Session session = new Session("127.0.0.1",6667,"root","root");
        session.open();

        String deviceId = "root.sestest.wf01.wt01";


        List<MeasurementSchema> schemaList = new ArrayList<>();
        schemaList.add(new MeasurementSchema("s0", TSDataType.INT32));
        schemaList.add(new MeasurementSchema("s1", TSDataType.INT32));
        schemaList.add(new MeasurementSchema("s2", TSDataType.INT32));


        //根据maxRowNumber初始化多少个timestamp和values测量点个数
        Tablet tablet = new Tablet(deviceId, schemaList, 1000);

        Object[] values = tablet.values;


        for (long time = 0; time < 1000; time++) {
            int row = tablet.rowSize++;
            tablet.timestamps[row]=time;
            for (int i = 0; i < 3; i++) {
                ((int[])values[i])[row] = 99;
            }
        }

        if (tablet.rowSize != 0) {
            session.insertTablet(tablet);
            tablet.reset();
        }

        session.close();
    }

附上values结构

 

方式四:JDBC

IoTDB JDBCdemo

 

 

总结

insertTablet  >  insertRecord指定类型  >  insertRecord不指定类型  > JDBC 

以上是个人觉得几种方式性能排序

insertTablet方式需要Tablet中的测量点都有数据,如果库中root.sestest.wf01.wt01设备还有s3测量点。这样也是可以插的

times0s1s2
1999999
2999999
3999999

 

 

 

 

 

insertRecord 没有类型信息,则服务器必须进行类型推断

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值