kudu upsert data api

课程链接: http://edu.51cto.com/course/15174.html

kudu对插入数据进行更新操作

    try {
        String tableName = "wyh_main";

        KuduClient client = new KuduClient.KuduClientBuilder("hadoop4,hadoop5,hadoop6").defaultAdminOperationTimeoutMs(600000).build();
        // 获取table
        KuduTable table = client.openTable(tableName);

        // 获取一个会话
        KuduSession session = client.newSession();
        session.setTimeoutMillis(60000);
        session.setFlushMode(SessionConfiguration.FlushMode.MANUAL_FLUSH);
        session.setMutationBufferSpace(10000);

        // 插入时,初始时间
        long startTime = System.currentTimeMillis();
        System.out.println("startTime is : " + System.currentTimeMillis());

        int val = 0;
        // 插入数据
        for (int i = 0; i < 90; i++) {
            Upsert upsert = table.newUpsert();
            PartialRow row = upsert.getRow();
            row.addLong(0, i);
            row.addLong(1, i);
            row.addLong(2, i);
            row.addString(3, "weiyunhao1");
            session.apply(upsert);
            if (val % 10 == 0) {
                session.flush();
                val = 0;
            }
            val++;
        }
        session.flush();
        // 插入时结束时间
        long endTime = System.currentTimeMillis();
        System.out.println("the timeperiod executed is : " + (endTime - startTime));

你可能感兴趣的:(kudu,kudu)