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


Java CellUtil.updateLatestStamp方法代碼示例

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


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

示例1: updateDeleteLatestVersionTimeStamp

import org.apache.hadoop.hbase.CellUtil; //導入方法依賴的package包/類
void updateDeleteLatestVersionTimeStamp(Cell cell, Get get, int count, byte[] byteNow)
    throws IOException {
  List<Cell> result = get(get, false);

  if (result.size() < count) {
    // Nothing to delete
    CellUtil.updateLatestStamp(cell, byteNow, 0);
    return;
  }
  if (result.size() > count) {
    throw new RuntimeException("Unexpected size: " + result.size());
  }
  Cell getCell = result.get(count - 1);
  CellUtil.setTimestamp(cell, getCell.getTimestamp());
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:16,代碼來源:HRegion.java

示例2: prePrepareTimeStampForDeleteVersion

import org.apache.hadoop.hbase.CellUtil; //導入方法依賴的package包/類
@Override
public void prePrepareTimeStampForDeleteVersion(
    ObserverContext<RegionCoprocessorEnvironment> ctx, Mutation delete, Cell cell,
    byte[] byteNow, Get get) throws IOException {
  // Nothing to do if we are not filtering by visibility
  if (!authorizationEnabled) {
    return;
  }

  CellVisibility cellVisibility = null;
  try {
    cellVisibility = delete.getCellVisibility();
  } catch (DeserializationException de) {
    throw new IOException("Invalid cell visibility specified " + delete, de);
  }
  // The check for checkForReservedVisibilityTagPresence happens in preBatchMutate happens.
  // It happens for every mutation and that would be enough.
  List<Tag> visibilityTags = new ArrayList<Tag>();
  if (cellVisibility != null) {
    String labelsExp = cellVisibility.getExpression();
    try {
      visibilityTags = this.visibilityLabelService.createVisibilityExpTags(labelsExp, false,
          false);
    } catch (InvalidLabelException e) {
      throw new IOException("Invalid cell visibility specified " + labelsExp, e);
    }
  }
  get.setFilter(new DeleteVersionVisibilityExpressionFilter(visibilityTags,
      VisibilityConstants.SORTED_ORDINAL_SERIALIZATION_FORMAT));
  List<Cell> result = ctx.getEnvironment().getRegion().get(get, false);

  if (result.size() < get.getMaxVersions()) {
    // Nothing to delete
    CellUtil.updateLatestStamp(cell, Long.MIN_VALUE);
    return;
  }
  if (result.size() > get.getMaxVersions()) {
    throw new RuntimeException("Unexpected size: " + result.size()
        + ". Results more than the max versions obtained.");
  }
  Cell getCell = result.get(get.getMaxVersions() - 1);
  CellUtil.setTimestamp(cell, getCell.getTimestamp());

  // We are bypassing here because in the HRegion.updateDeleteLatestVersionTimeStamp we would
  // update with the current timestamp after again doing a get. As the hook as already determined
  // the needed timestamp we need to bypass here.
  // TODO : See if HRegion.updateDeleteLatestVersionTimeStamp() could be
  // called only if the hook is not called.
  ctx.bypass();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:51,代碼來源:VisibilityController.java


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