當前位置: 首頁>>代碼示例>>Java>>正文


Java IndexSpecification.getIndexColumns方法代碼示例

本文整理匯總了Java中org.apache.hadoop.hbase.index.IndexSpecification.getIndexColumns方法的典型用法代碼示例。如果您正苦於以下問題:Java IndexSpecification.getIndexColumns方法的具體用法?Java IndexSpecification.getIndexColumns怎麽用?Java IndexSpecification.getIndexColumns使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.hadoop.hbase.index.IndexSpecification的用法示例。


在下文中一共展示了IndexSpecification.getIndexColumns方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: doGetAndGroupByTS

import org.apache.hadoop.hbase.index.IndexSpecification; //導入方法依賴的package包/類
private static Multimap<Long, Cell> doGetAndGroupByTS(List<IndexSpecification> indexSpecs,
    HRegion userRegion, Cell deleteKV, List<IndexSpecification> indicesToConsider)
    throws IOException {

  Get get = new Get(deleteKV.getRow());
  long maxTS = HConstants.LATEST_TIMESTAMP;

  if (deleteKV.getTimestamp() < maxTS) {
    // Add +1 to make the current get includes the timestamp
    maxTS = deleteKV.getTimestamp() + 1;
  }
  get.setTimeRange(0L, maxTS);

  for (IndexSpecification index : indexSpecs) {
    // Get all indices involves this family/qualifier
    if (index.contains(deleteKV.getFamily(), deleteKV.getQualifier())) {
      indicesToConsider.add(index);
      for (ColumnQualifier cq : index.getIndexColumns()) {
        get.addColumn(cq.getColumnFamily(), cq.getQualifier());
      }
    }
  }
  if (((KeyValue) deleteKV).isDeleteType()) {
    get.setMaxVersions(1);
  } else if (((KeyValue) deleteKV).isDeleteColumnOrFamily()) {
    get.setMaxVersions();
  }
  List<KeyValue> userKVs = userRegion.get(get).list();

  // Group KV based on timestamp
  Multimap<Long, Cell> groupedKV = HashMultimap.create();

  if (userKVs != null) {
    for (Cell userKV : userKVs) {
      groupedKV.put(userKV.getTimestamp(), userKV);
    }
  }
  return groupedKV;
}
 
開發者ID:tenggyut,項目名稱:HIndex,代碼行數:40,代碼來源:IndexRegionObserver.java

示例2: isIndexSuitable

import org.apache.hadoop.hbase.index.IndexSpecification; //導入方法依賴的package包/類
private boolean isIndexSuitable(IndexSpecification index, List<Column> cols,
    Map<Column, LeafFilterNode> leafNodes) {
  int matchedCols = 0;
  for (ColumnQualifier cq : index.getIndexColumns()) {
    Column column = new Column(cq.getColumnFamily(), cq.getQualifier(), cq.getValuePartition());
    if (cols.contains(column)) {
      matchedCols++;
      // leafNodes.get(column) will never be null.. Don't worry
      if (leafNodes.get(column).getFilterColumnValueDetail() instanceof FilterColumnValueRange) {
        // When the condition on the column is a range condition, we need to ensure in this index
        // 1. The column is the last column
        // or
        // 2. There are no columns in this index which is part of the cols list
        if (matchedCols != cols.size()) {
          return false;
        }
      }
    } else {
      if (matchedCols != cols.size()) {
        return false;
      }
    }
    if (matchedCols == cols.size()) {
      return true;
    }
  }
  return false;
}
 
開發者ID:tenggyut,項目名稱:HIndex,代碼行數:29,代碼來源:ScanFilterEvaluator.java

示例3: prepareIndexDelete

import org.apache.hadoop.hbase.index.IndexSpecification; //導入方法依賴的package包/類
public static Delete prepareIndexDelete(Delete userDelete, IndexSpecification index,
    byte[] indexRegionStartKey) throws IOException {
  ByteArrayBuilder indexRow =
      IndexUtils.getIndexRowKeyHeader(index, indexRegionStartKey, userDelete.getRow());
  boolean update = false;
  for (ColumnQualifier cq : index.getIndexColumns()) {
    Cell kvFound = null;
    for (Entry<byte[], List<Cell>> entry : userDelete.getFamilyCellMap().entrySet()) {
      for (Cell cell : entry.getValue()) {
        Cell kv = KeyValueUtil.ensureKeyValue(cell);
        if (Bytes.equals(cq.getColumnFamily(), kv.getFamily())
            && Bytes.equals(cq.getQualifier(), kv.getQualifier())) {
          kvFound = kv;
          update = true;
          break;
        }
      }
    }
    if (kvFound == null) {
      indexRow.position(indexRow.position() + cq.getMaxValueLength());
    } else {
      IndexUtils.updateRowKeyForKV(cq, kvFound, indexRow);
    }
  }
  if (update) {
    // Append the actual row key at the end of the index row key.
    indexRow.put(userDelete.getRow());
    Delete idxDelete = new Delete(indexRow.array());
    idxDelete.deleteColumn(Constants.IDX_COL_FAMILY, Constants.IDX_COL_QUAL,
      userDelete.getTimeStamp());
    idxDelete.setDurability(Durability.SKIP_WAL);
    return idxDelete;
  }
  return null;
}
 
開發者ID:tenggyut,項目名稱:HIndex,代碼行數:36,代碼來源:IndexUtils.java

示例4: getIndexDeletes

import org.apache.hadoop.hbase.index.IndexSpecification; //導入方法依賴的package包/類
private static Collection<Delete> getIndexDeletes(List<IndexSpecification> indexSpecs,
    HRegion userRegion, HRegion indexRegion, Cell deleteKV) throws IOException {
  Collection<Delete> indexDeletes = new LinkedHashSet<Delete>();
  List<IndexSpecification> indicesToUpdate = new LinkedList<IndexSpecification>();
  Multimap<Long, Cell> groupedKV =
      doGetAndGroupByTS(indexSpecs, userRegion, deleteKV, indicesToUpdate);

  // There can be multiple index kvs for each user kv
  // So, prepare all resultant index delete kvs for this user delete kv
  for (Entry<Long, Collection<Cell>> entry : groupedKV.asMap().entrySet()) {
    for (IndexSpecification index : indicesToUpdate) {
      ByteArrayBuilder indexRow =
          IndexUtils.getIndexRowKeyHeader(index, indexRegion.getStartKey(), deleteKV.getRow());
      boolean update = false;
      for (ColumnQualifier cq : index.getIndexColumns()) {
        Cell kvFound = null;
        for (Cell kv : entry.getValue()) {
          if (Bytes.equals(cq.getColumnFamily(), kv.getFamily())
              && Bytes.equals(cq.getQualifier(), kv.getQualifier())) {
            kvFound = kv;
            update = true;
            break;
          }
        }
        if (kvFound == null) {
          indexRow.position(indexRow.position() + cq.getMaxValueLength());
        } else {
          IndexUtils.updateRowKeyForKV(cq, kvFound, indexRow);
        }
      }
      if (update) {
        // Append the actual row key at the end of the index row key.
        indexRow.put(deleteKV.getRow());
        Delete idxDelete = new Delete(indexRow.array());
        if (((KeyValue) deleteKV).isDeleteType()) {
          idxDelete
              .deleteColumn(Constants.IDX_COL_FAMILY, Constants.IDX_COL_QUAL, entry.getKey());
        } else {
          idxDelete.deleteFamily(Constants.IDX_COL_FAMILY, entry.getKey());
        }
        indexDeletes.add(idxDelete);
      }
    }
  }
  return indexDeletes;
}
 
開發者ID:tenggyut,項目名稱:HIndex,代碼行數:47,代碼來源:IndexRegionObserver.java


注:本文中的org.apache.hadoop.hbase.index.IndexSpecification.getIndexColumns方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。