Настройка производительности Calcite sql

Я использую calcite, чтобы выполнить какую-то работу sql, ниже приведен простой тестовый код:

String json = "{\"DATA\":{\"CAR_NO\":123123},\"USER_ID\":300,\"USER_NAME\":\"user1\"}";
    ResultSet resultSet = null;
    long begin = System.currentTimeMillis();

    for (int j = 0; j < 1000; j++) {
        Statement statement = connection.createStatement();

        rootSchema.add("testDB", new JsonSchema("testTAB", json));

        resultSet = statement.executeQuery(
                "select * from \"testDB\".\"testTAB\" where USER_ID =300 order by USER_ID desc ");

        while (resultSet.next()) {
            JSONObject jo = new JSONObject();
            int n = resultSet.getMetaData().getColumnCount();
            for (int i = 1; i <= n; i++) {
                jo.put(resultSet.getMetaData().getColumnName(i), resultSet.getObject(i));
            }
        }

        resultSet.close();
        statement.close();
        connection.close();
    }

    System.out.println("Time elapsed:" + (System.currentTimeMillis() - begin));

Время выполнения для кальцита кажется мне медленным, это занимает 13 секунд для цикла for, чтобы выполнить 500 раз, 22 секунды для 1000 раз. И я нахожу statement.executeQuery занимает большую часть времени
Любой ключ к настройке производительности? Спасибо

0 ответов

Другие вопросы по тегам