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


Java Result.getRow方法代碼示例

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


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

示例1: getAll

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
/**
 * 獲取單張表的所有記錄
 * 
 * @throws IOException
 */
public static Map<byte[], byte[]> getAll(String TableName, String ColumnFamily, String ColumnName)
		throws IOException {
	Map<byte[], byte[]> tableContent = new HashMap<byte[], byte[]>();
	Scan s = new Scan();
	s.addColumn(Bytes.toBytes(ColumnFamily), Bytes.toBytes(ColumnName));
	s.setMaxVersions(1);
	s.setCacheBlocks(false);
	ResultScanner rs = hbase_table.getScanner(s);
	for (Result r : rs) {
		byte[] key = r.getRow();
		byte[] value = r.getValue(Bytes.toBytes(ColumnFamily), Bytes.toBytes(ColumnName));
		tableContent.put(key, value);
	}
	rs.close();
	return tableContent;
}
 
開發者ID:ItGql,項目名稱:SparkIsax,代碼行數:22,代碼來源:HBaseUtils.java

示例2: parseResult

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override public String parseResult(Result result) {
  byte[] rowkey = result.getRow();
  // aId, uId, cId
  long orderKey = Bytes.toLong(rowkey, 4);
  long custKey = Bytes.toLong(result.getValue(FAMILY_NAME, Bytes.toBytes("ck")));
  String status = Bytes.toString(result.getValue(FAMILY_NAME, Bytes.toBytes("st")));
  int totalPrice = Bytes.toInt(result.getValue(FAMILY_NAME, Bytes.toBytes("t")));
  int date = Bytes.toInt(result.getValue(FAMILY_NAME, Bytes.toBytes("d")));
  int priority = Bytes.toInt(result.getValue(FAMILY_NAME, Bytes.toBytes("p")));
  String clerk = Bytes.toString(result.getValue(FAMILY_NAME, Bytes.toBytes("cl")));
  int shipPriority = Bytes.toInt(result.getValue(FAMILY_NAME, Bytes.toBytes("sh")));
  String comment = Bytes.toString(result.getValue(FAMILY_NAME, Bytes.toBytes("cm")));
  StringBuilder sb = new StringBuilder();
  sb.append("{");
  sb.append("orderKey=").append(orderKey).append(",");
  sb.append("custKey=").append(custKey).append(",");
  sb.append("status=").append(status).append(",");
  sb.append("totalPrice=").append(totalPrice).append(",");
  sb.append("date=").append(date).append(",");
  sb.append("priority=").append(priority).append(",");
  sb.append("clerk=").append(clerk).append(",");
  sb.append("shipPriority=").append(shipPriority).append(",");
  sb.append("comment=").append(comment).append("}");
  return sb.toString();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:26,代碼來源:TPCHWorkload.java

示例3: mapRow

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override
public TraceAnnotationDto mapRow(Result res, int rowNum) throws Exception {
    String rowKey = new String(res.getRow());
    NavigableMap<byte[], byte[]> familyMap = res.getFamilyMap(TABLE_ANNOTATION_COLUMN_FAMILY.getBytes());


    String[] ss = rowKey.split("_");
    String iface = ss[0];
    String method = ss[1];
    String type = ss[2];
    long timestamp = Long.parseLong(ss[3]);

    String traceId = "", value = "";
    for (Map.Entry<byte[], byte[]> entry : familyMap.entrySet()) {
        traceId = new String(entry.getKey());
        value = new String(entry.getValue());
    }

    TraceAnnotationDto tad = new TraceAnnotationDto();
    tad.setRowKey(rowKey).setIface(iface).setMethod(method).setType(type).setTimestamp(timestamp);
    tad.setTraceId(traceId).setValue(value);
    return tad;
}
 
開發者ID:JThink,項目名稱:SkyEye,代碼行數:24,代碼來源:TraceAnnotationDto.java

示例4: mapRow

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override
public TraceTimeConsumeDto mapRow(Result res, int rowNum) throws Exception {
    TraceTimeConsumeDto dto = new TraceTimeConsumeDto();
    Map<byte[], byte[]> familyMap = res.getFamilyMap(Constants.TABLE_TIME_CONSUME_COLUMN_FAMILY.getBytes());
    Set<Map.Entry<byte[], byte[]>> entrySet = familyMap.entrySet();
    for (Map.Entry<byte[], byte[]> en : entrySet) {
        dto.setTraceId(new String(en.getKey())).setConsumeTime(RadixUtil.bytesToLong(en.getValue()));
    }
    String[] ss = new String(res.getRow()).split(Constants.UNDER_LINE);
    String iface = ss[0];
    String method = ss[1];
    Long startTime = Long.parseLong(ss[2]);
    Long endTime = startTime + dto.getConsumeTime();
    String rowKey = new String(res.getRow());

    dto.setIface(iface).setMethod(method).setStartTime(startTime).setEndTime(endTime).setRowKey(rowKey);
    return dto;
}
 
開發者ID:JThink,項目名稱:SkyEye,代碼行數:19,代碼來源:TraceTimeConsumeRowMapper.java

示例5: doAnAction

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
public void doAnAction() throws Exception {
  Get g = new Get(targetRow);
  Result res = table.get(g);
  byte[] gotValue = null;
  if (res.getRow() == null) {
    // Trying to verify but we didn't find the row - the writing
    // thread probably just hasn't started writing yet, so we can
    // ignore this action
    return;
  }

  for (byte[] family : targetFamilies) {
    for (int i = 0; i < NUM_COLS_TO_CHECK; i++) {
      byte qualifier[] = Bytes.toBytes("col" + i);
      byte thisValue[] = res.getValue(family, qualifier);
      if (gotValue != null && !Bytes.equals(gotValue, thisValue)) {
        gotFailure(gotValue, res);
      }
      numVerified++;
      gotValue = thisValue;
    }
  }
  numRead.getAndIncrement();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:25,代碼來源:TestAcidGuarantees.java

示例6: createModelFromResults

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
private CellSetModel createModelFromResults(Result[] results) {
  CellSetModel cellSetModel = new CellSetModel();
  for (Result rs : results) {
    byte[] rowKey = rs.getRow();
    RowModel rModel = new RowModel(rowKey);
    List<Cell> kvs = rs.listCells();
    for (Cell kv : kvs) {
      rModel.addCell(new CellModel(CellUtil.cloneFamily(kv), CellUtil.cloneQualifier(kv), kv
          .getTimestamp(), CellUtil.cloneValue(kv)));
    }
    cellSetModel.addRow(rModel);
  }
  return cellSetModel;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:15,代碼來源:ProtobufStreamingUtil.java

示例7: mapRow

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override
    public BaseDataPoint mapRow(Result result, int rowNum) throws Exception {
        if (result.isEmpty()) {
//            return Collections.emptyList();
            return null;
        }
        final byte[] distributedRowKey = result.getRow();
//        List<BaseDataPoint> dataPoints = new ArrayList<>();
        EasyHBaseBo bo = new EasyHBaseBo();
        for (Cell cell : result.rawCells()) {
            if (CellUtil.matchingFamily(cell, HBaseTables.EASYHBASE_CF)) {

                bo.setRowkey(Bytes.toString(cell.getRow()));
                bo.setValue(Bytes.toString(cell.getValue()));
                bo.setTimestamp(cell.getTimestamp());
//                dataPoints.add(bo);
//                List<T> candidates = new ArrayList<>();
//                for (T candidate : candidates) {
//                    candidate.setRowkey(candidate.getRowkey());
//                    candidate.setValue(candidate.getValue());
//                    candidate.setTimestamp(candidate.getTimestamp());
//                    dataPoints.add(candidate);
//                }
            }
        }
        // Reverse sort as timestamp is stored in a reversed order.
//        Collections.sort(dataPoints, REVERSE_TIMESTAMP_COMPARATOR);
        return bo;
    }
 
開發者ID:fchenxi,項目名稱:easyhbase,代碼行數:30,代碼來源:EasyHBaseMapperV2.java

示例8: testExpectedNumberOfCellsPerPartialResult

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
public void testExpectedNumberOfCellsPerPartialResult(Scan baseScan, int expectedNumberOfCells)
    throws Exception {

  if (LOG.isInfoEnabled()) LOG.info("groupSize:" + expectedNumberOfCells);

  // Use the cellHeapSize to set maxResultSize such that we know how many cells to expect back
  // from the call. The returned results should NOT exceed expectedNumberOfCells but may be less
  // than it in cases where expectedNumberOfCells is not an exact multiple of the number of
  // columns in the table.
  Scan scan = new Scan(baseScan);
  scan.setAllowPartialResults(true);
  scan.setMaxResultSize(getResultSizeForNumberOfCells(expectedNumberOfCells));

  ResultScanner scanner = TABLE.getScanner(scan);
  Result result = null;
  byte[] prevRow = null;
  while ((result = scanner.next()) != null) {
    assertTrue(result.rawCells() != null);

    // Cases when cell count won't equal expectedNumberOfCells:
    // 1. Returned result is the final result needed to form the complete result for that row
    // 2. It is the first result we have seen for that row and thus may have been fetched as
    // the last group of cells that fit inside the maxResultSize
    assertTrue(
        "Result's cell count differed from expected number. result: " + result,
        result.rawCells().length == expectedNumberOfCells || !result.isPartial()
            || !Bytes.equals(prevRow, result.getRow()));
    prevRow = result.getRow();
  }

  scanner.close();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:33,代碼來源:TestPartialResultsFromClientSide.java

示例9: notifyInsertion

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
/**
 * @param row
 * @throws IOException
 */
void notifyInsertion(byte[] row, long newAdded) throws IOException {
  Result bucketEntry = getRowOrBefore(bucketTable, row, MDHBaseAdmin.BUCKET_FAMILY);
  byte[] bucketKey = bucketEntry.getRow();
  long startTime = System.currentTimeMillis();
  long size = bucketTable.incrementColumnValue(bucketKey, MDHBaseAdmin.BUCKET_FAMILY,
      MDHBaseAdmin.BUCKET_SIZE_QUALIFIER, newAdded);
  incBucketTotalCount++;
  incBucketTotalTime += System.currentTimeMillis() - startTime;
  maySplit(bucketKey, size);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:15,代碼來源:MDIndex.java

示例10: map

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override
protected void map(ImmutableBytesWritable key, Result value, Context context)
    throws IOException, InterruptedException {
  byte[] row = value.getRow();
  Counter c = getCounter(row);
  c.increment(1);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:8,代碼來源:IntegrationTestWithCellVisibilityLoadAndVerify.java

示例11: insertOneRecord

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
@Override protected void insertOneRecord(AbstractDITBRecord record) throws IOException {
  // note, MD-HBase get before update, we summarize the time in get seperately
  MDPoint point = record.toMDPoint();
  byte[] row = MDUtils.bitwiseZip(point.values, mdAdmin.getDimensions());
  // get before row
  long startTime = System.currentTimeMillis();
  Scan scan = new Scan();
  scan.addFamily(MDHBaseAdmin.BUCKET_FAMILY);
  scan.setReversed(true);
  scan.setStartRow(row);
  scan.setCacheBlocks(false);
  scan.setCaching(1);
  scan.setSmall(true);
  ResultScanner scanner = table.getScanner(scan);
  Result result = scanner.next();
  scanner.close();
  gbuTime += System.currentTimeMillis() - startTime;
  gbuCount++;
  // default scan
  if (result == null) {
    row = mdAdmin.getBucketSuffixRow(point);
  } else {
    row = result.getRow();
  }
  table.incrementColumnValue(row, MDHBaseAdmin.BUCKET_FAMILY,
      MDHBaseAdmin.BUCKET_SIZE_QUALIFIER, 1);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:28,代碼來源:PerfMD.java

示例12: deleteTableData

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
/**
 * Provide an existing table name to truncate.
 * Scans the table and issues a delete for each row read.
 * @param tableName existing table
 * @return HTable to that new table
 * @throws IOException
 */
public HTable deleteTableData(TableName tableName) throws IOException {
  HTable table = new HTable(getConfiguration(), tableName);
  Scan scan = new Scan();
  ResultScanner resScan = table.getScanner(scan);
  for(Result res : resScan) {
    Delete del = new Delete(res.getRow());
    table.delete(del);
  }
  resScan = table.getScanner(scan);
  resScan.close();
  return table;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:20,代碼來源:HBaseTestingUtility.java

示例13: splitBucket

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
private void splitBucket(byte[] splitKey) throws IOException {
  Result bucketEntry = getRowOrBefore(bucketTable, splitKey, MDHBaseAdmin.BUCKET_FAMILY);
  byte[] bucketKey = bucketEntry.getRow();
  int prefixLength = Bytes.toInt(
      bucketEntry.getValue(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_PREFIX_LEN_QUALIFIER));
  long bucketSize = Bytes.toLong(
      bucketEntry.getValue(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_SIZE_QUALIFIER));
  int newPrefixLength = prefixLength + 1;
  if (newPrefixLength > 32 * 2) {
    return; // exceeds the maximum prefix length.
  }
  byte[] newChildKey0 = bucketKey;
  byte[] newChildKey1 = MDUtils.makeBit(bucketKey, prefixLength, dimensions);
  Scan scan = new Scan(newChildKey0, newChildKey1);
  scan.addFamily(MDHBaseAdmin.SECONDARY_FAMILY);
  scan.setCaching(1000);
  ResultScanner scanner = secondaryTable.getScanner(scan);
  long newSize = 0L;
  for (Result result : scanner) {
    newSize += result.getFamilyMap(MDHBaseAdmin.SECONDARY_FAMILY).size();
  }
  splitTimes++;
  scanner.close();
  Put put0 = new Put(newChildKey0);
  put0.addColumn(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_PREFIX_LEN_QUALIFIER,
      Bytes.toBytes(newPrefixLength));
  put0.addColumn(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_SIZE_QUALIFIER,
      Bytes.toBytes(newSize));
  Put put1 = new Put(newChildKey1);
  put1.addColumn(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_PREFIX_LEN_QUALIFIER,
      Bytes.toBytes(newPrefixLength));
  put1.addColumn(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_SIZE_QUALIFIER,
      Bytes.toBytes(bucketSize - newSize));
  List<Put> puts = new ArrayList<>(2);
  puts.add(put0);
  puts.add(put1);
  bucketTable.put(puts);
  maySplit(newChildKey0, newSize);
  maySplit(newChildKey1, bucketSize - newSize);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:41,代碼來源:MDIndex.java

示例14: fetchBucket

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
/**
 * fetches a bucket which holds the queried row.
 *
 * @param row a queried row key
 * @return a bucket which holds the queried row.
 * @throws IOException
 */
public MDBucket fetchBucket(byte[] row) throws IOException {
  Result bucketEntry = getRowOrBefore(bucketTable, row, MDHBaseAdmin.BUCKET_FAMILY);
  byte[] bucketKey = bucketEntry.getRow();
  // prefix length has been written while creating table, defined to #dimension
  int prefixLength = Bytes.toInt(
      bucketEntry.getValue(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_PREFIX_LEN_QUALIFIER));
  MDRange[] ranges = toRanges(bucketKey, prefixLength);
  return createBucket(ranges);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:17,代碼來源:MDIndex.java

示例15: findBucketsInRange

import org.apache.hadoop.hbase.client.Result; //導入方法依賴的package包/類
/**
 * finds buckets which intersect with the query region.
 *
 * @param ranges
 * @return
 * @throws IOException
 */
public Iterable<MDBucket> findBucketsInRange(MDRange[] ranges, int cacheSize) throws IOException {
  int[] mins = new int[ranges.length];
  int[] maxs = new int[ranges.length];
  for (int i = 0; i < ranges.length; i++) {
    mins[i] = ranges[i].min;
    maxs[i] = ranges[i].max;
  }
  byte[] probeKey = MDUtils.bitwiseZip(mins, dimensions);
  Result bucketEntry = getRowOrBefore(bucketTable, probeKey, MDHBaseAdmin.BUCKET_FAMILY);
  byte[] startKey = bucketEntry.getRow();
  //    byte[] stopKey = Bytes.incrementBytes(MDUtils.bitwiseZip(maxs), 1L);
  byte[] stopKey = MDUtils.increment(MDUtils.bitwiseZip(maxs, dimensions));
  Scan scan = new Scan(startKey, stopKey);
  scan.addFamily(MDHBaseAdmin.BUCKET_FAMILY);
  scan.setCaching(cacheSize);
  ResultScanner scanner = bucketTable.getScanner(scan);
  List<MDBucket> hitBuckets = new LinkedList<>();
  long startTime = System.currentTimeMillis();
  int counter = 0;
  for (Result result : scanner) {
    ++counter;
    byte[] row = result.getRow();
    int pl = Bytes.toInt(
        result.getValue(MDHBaseAdmin.BUCKET_FAMILY, MDHBaseAdmin.BUCKET_PREFIX_LEN_QUALIFIER));
    MDRange[] rs = toRanges(row, pl);
    boolean intersect = true;
    for (int i = 0; i < rs.length; i++) {
      if (!ranges[i].intersect(rs[i])) {
        intersect = false;
        break;
      }
    }
    if (intersect) {
      hitBuckets.add(createBucket(rs));
    }
  }
  lastScanTotalNumber = counter;
  lastScanTotalTime = System.currentTimeMillis() - startTime;
  scanner.close();
  return hitBuckets;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:49,代碼來源:MDIndex.java


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