All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.hadoop.hive.accumulo.columns.HiveAccumuloMapColumnMapping Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 org.apache.hadoop.hive.accumulo.columns;

import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.hadoop.hive.accumulo.AccumuloHiveConstants;

import com.google.common.base.Preconditions;

/**
 * ColumnMapping for combining Accumulo columns into a single Hive Map. Expects ColumnEncoding
 * values for both the Key and Value of the Map.
 */
public class HiveAccumuloMapColumnMapping extends ColumnMapping {

  protected final String columnFamily, columnQualifierPrefix;
  protected final ColumnEncoding keyEncoding, valueEncoding;

  /**
   * @param columnFamily
   *          The column family that all qualifiers within should be placed into the same Hive map
   * @param columnQualifierPrefix
   *          The column qualifier prefix to include in the map, null is treated as an empty prefix
   * @param keyEncoding
   *          The encoding scheme for keys in this column family
   * @param valueEncoding
   *          The encoding scheme for the Accumulo values
   */
  public HiveAccumuloMapColumnMapping(String columnFamily, String columnQualifierPrefix,
      ColumnEncoding keyEncoding, ColumnEncoding valueEncoding, String columnName,
      String columnType) {
    // Try to make something reasonable to pass up to the base class
    super((null == columnFamily ? "" : columnFamily) + AccumuloHiveConstants.COLON, valueEncoding,
        columnName, columnType);

    Preconditions.checkNotNull(columnFamily, "Must provide a column family");

    this.columnFamily = columnFamily;
    this.columnQualifierPrefix = (null == columnQualifierPrefix) ? "" : columnQualifierPrefix;
    this.keyEncoding = keyEncoding;
    this.valueEncoding = valueEncoding;
  }

  public String getColumnFamily() {
    return columnFamily;
  }

  public String getColumnQualifierPrefix() {
    return columnQualifierPrefix;
  }

  public ColumnEncoding getKeyEncoding() {
    return keyEncoding;
  }

  public ColumnEncoding getValueEncoding() {
    return valueEncoding;
  }

  @Override
  public boolean equals(Object o) {
    if (o instanceof HiveAccumuloMapColumnMapping) {
      HiveAccumuloMapColumnMapping other = (HiveAccumuloMapColumnMapping) o;
      return columnFamily.equals(other.columnFamily)
          && columnQualifierPrefix.equals(other.columnQualifierPrefix)
          && keyEncoding.equals(other.keyEncoding) && valueEncoding.equals(other.valueEncoding);
    }

    return false;
  }

  @Override
  public int hashCode() {
    HashCodeBuilder hcb = new HashCodeBuilder(23, 31);
    hcb.append(columnFamily).append(columnQualifierPrefix).append(keyEncoding)
        .append(valueEncoding);
    return hcb.toHashCode();
  }

  @Override
  public String toString() {
    return "[" + this.getClass().getSimpleName() + ": " + columnFamily + ":"
        + columnQualifierPrefix + "* encoding: " + keyEncoding + ":" + valueEncoding + "]";
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy