/* * Copyright (c) 2014 Hewlett-Packard Development Company, L.P. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. */ package monasca.api.infrastructure.persistence.vertica; import java.util.Map; import org.skife.jdbi.v2.Handle; import monasca.common.persistence.SqlQueries; /** * Vertica utilities for building metric queries. */ final class MetricQueries { private MetricQueries() {} static String buildJoinClauseFor(Map dimensions) { StringBuilder sbJoin = null; if (dimensions != null) { sbJoin = new StringBuilder(); for (int i = 0; i < dimensions.size(); i++) sbJoin.append(" inner join MonMetrics.Dimensions d").append(i).append(" on d").append(i) .append(".name = :dname").append(i).append(" and d").append(i) .append(".value = " + ":dvalue").append(i).append(" and dd.dimension_set_id = d") .append(i).append("" + ".dimension_set_id"); } return sbJoin == null ? "" : sbJoin.toString(); } static Map dimensionsFor(Handle handle, byte[] dimensionSetId) { return SqlQueries.keyValuesFor(handle, "select name, value from MonMetrics.Dimensions " + "where" + " dimension_set_id = ?", dimensionSetId); } }