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


Java CompareOp.EQUAL屬性代碼示例

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


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

示例1: QueryByCondition2

public static void QueryByCondition2(String tableName) {

        try {
            HTablePool pool = new HTablePool(configuration, 1000);
            HTable table = (HTable) pool.getTable(tableName);
            Filter filter = new SingleColumnValueFilter(Bytes
                    .toBytes("column1"), null, CompareOp.EQUAL, Bytes
                    .toBytes("aaa")); // 當列column1的值為aaa時進行查詢
            Scan s = new Scan();
            s.setFilter(filter);
            ResultScanner rs = table.getScanner(s);
            for (Result r : rs) {
                System.out.println("獲得到rowkey:" + new String(r.getRow()));
                for (KeyValue keyValue : r.raw()) {
                    System.out.println("列:" + new String(keyValue.getFamily())
                            + "====值:" + new String(keyValue.getValue()));
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
 
開發者ID:yjp123456,項目名稱:SparkDemo,代碼行數:23,代碼來源:MyClass.java

示例2: printRange

public static String printRange(Range r) {
  StringBuilder sb = new StringBuilder();
  sb.append("[" + Bytes.toString(r.getFamily()) + ":" + Bytes.toString(r.getQualifier())
      + "], values (");
  if (r.getStartValue() != null) {
    sb.append(LCIndexConstant.getStringOfValueAndType(r.getDataType(), r.getStartValue()));
    if (r.getStartType() == CompareOp.EQUAL || r.getStartType() == CompareOp.NOT_EQUAL) {
      sb.append(" <== ").append(r.getStartType()).append(" )");
      return sb.toString();
    }
  } else {
    sb.append("null");
  }
  sb.append(", ");
  if (r.getStopValue() != null) {
    sb.append(LCIndexConstant.getStringOfValueAndType(r.getDataType(), r.getStopValue()));
  } else {
    sb.append("MAX");
  }
  sb.append(")");
  return sb.toString();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:22,代碼來源:LCIndexConstant.java

示例3: configure

@Override
public void configure(JobConf job) {
  try {
    HTable exampleTable = new HTable(HBaseConfiguration.create(job),
      Bytes.toBytes("exampleDeprecatedTable"));
    // mandatory
    setHTable(exampleTable);
    byte[][] inputColumns = new byte [][] { Bytes.toBytes("columnA"),
      Bytes.toBytes("columnB") };
    // mandatory
    setInputColumns(inputColumns);
    Filter exampleFilter = new RowFilter(CompareOp.EQUAL, new RegexStringComparator("aa.*"));
    // optional
    setRowFilter(exampleFilter);
  } catch (IOException exception) {
    throw new RuntimeException("Failed to configure for job.", exception);
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:18,代碼來源:TestTableInputFormat.java

示例4: configure

@Override
public void configure(JobConf job) {
  try {
    HTable exampleTable = new HTable(HBaseConfiguration.create(job),
      Bytes.toBytes("exampleDeprecatedTable"));
    // mandatory
    setHTable(exampleTable);
    byte[][] inputColumns = new byte [][] { Bytes.toBytes("columnA"),
      Bytes.toBytes("columnB") };
    // optional
    Scan scan = new Scan();
    for (byte[] family : inputColumns) {
      scan.addFamily(family);
    }
    Filter exampleFilter = new RowFilter(CompareOp.EQUAL, new RegexStringComparator("aa.*"));
    scan.setFilter(exampleFilter);
    setScan(scan);
  } catch (IOException exception) {
    throw new RuntimeException("Failed to configure for job.", exception);
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:21,代碼來源:TestTableInputFormat.java

示例5: createCompareOp

/**
* Takes a compareOperator symbol as a byte array and returns the corresponding CompareOperator
* <p>
* @param compareOpAsByteArray the comparatorOperator symbol as a byte array
* @return the Compare Operator
*/
 public static CompareFilter.CompareOp createCompareOp (byte [] compareOpAsByteArray) {
   ByteBuffer compareOp = ByteBuffer.wrap(compareOpAsByteArray);
   if (compareOp.equals(ParseConstants.LESS_THAN_BUFFER))
     return CompareOp.LESS;
   else if (compareOp.equals(ParseConstants.LESS_THAN_OR_EQUAL_TO_BUFFER))
     return CompareOp.LESS_OR_EQUAL;
   else if (compareOp.equals(ParseConstants.GREATER_THAN_BUFFER))
     return CompareOp.GREATER;
   else if (compareOp.equals(ParseConstants.GREATER_THAN_OR_EQUAL_TO_BUFFER))
     return CompareOp.GREATER_OR_EQUAL;
   else if (compareOp.equals(ParseConstants.NOT_EQUAL_TO_BUFFER))
     return CompareOp.NOT_EQUAL;
   else if (compareOp.equals(ParseConstants.EQUAL_TO_BUFFER))
     return CompareOp.EQUAL;
   else
     throw new IllegalArgumentException("Invalid compare operator");
 }
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:23,代碼來源:ParseFilter.java

示例6: initialize

@Override
protected void initialize(JobContext job) throws IOException {
  Connection connection = ConnectionFactory.createConnection(HBaseConfiguration.create(
      job.getConfiguration()));
  TableName tableName = TableName.valueOf("exampleTable");
  // mandatory
  initializeTable(connection, tableName);
  byte[][] inputColumns = new byte [][] { Bytes.toBytes("columnA"),
    Bytes.toBytes("columnB") };
  //optional
  Scan scan = new Scan();
  for (byte[] family : inputColumns) {
    scan.addFamily(family);
  }
  Filter exampleFilter = new RowFilter(CompareOp.EQUAL, new RegexStringComparator("aa.*"));
  scan.setFilter(exampleFilter);
  setScan(scan);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:18,代碼來源:TestTableInputFormat.java

示例7: buildScanner

private InternalScanner buildScanner(String keyPrefix, String value, HRegion r)
    throws IOException {
  // Defaults FilterList.Operator.MUST_PASS_ALL.
  FilterList allFilters = new FilterList();
  allFilters.addFilter(new PrefixFilter(Bytes.toBytes(keyPrefix)));
  // Only return rows where this column value exists in the row.
  SingleColumnValueFilter filter = new SingleColumnValueFilter(Bytes.toBytes("trans-tags"),
      Bytes.toBytes("qual2"), CompareOp.EQUAL, Bytes.toBytes(value));
  filter.setFilterIfMissing(true);
  allFilters.addFilter(filter);
  Scan scan = new Scan();
  scan.addFamily(Bytes.toBytes("trans-blob"));
  scan.addFamily(Bytes.toBytes("trans-type"));
  scan.addFamily(Bytes.toBytes("trans-date"));
  scan.addFamily(Bytes.toBytes("trans-tags"));
  scan.addFamily(Bytes.toBytes("trans-group"));
  scan.setFilter(allFilters);
  return r.getScanner(scan);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:19,代碼來源:TestHRegion.java

示例8: setStartType

/**
 * Set start type for start value.
 *
 * @param startType - can only be EQUAL, GREATER or GREATER_OR_EQUAL
 */
public void setStartType(CompareOp startType) {
  if (startType == CompareOp.EQUAL || startType == CompareOp.GREATER
      || startType == CompareOp.GREATER_OR_EQUAL) {
    this.startType = startType;
  } else {
    this.startType = startType;
    //			throw new IllegalArgumentException("Illegal start type: "
    //					+ startType.toString());
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:15,代碼來源:Range.java

示例9: initialize

protected void initialize(JobConf job, String table) throws IOException {
  Connection connection = ConnectionFactory.createConnection(HBaseConfiguration.create(job));
  TableName tableName = TableName.valueOf(table);
  // mandatory
  initializeTable(connection, tableName);
  byte[][] inputColumns = new byte [][] { Bytes.toBytes("columnA"),
    Bytes.toBytes("columnB") };
  // mandatory
  setInputColumns(inputColumns);
  Filter exampleFilter = new RowFilter(CompareOp.EQUAL, new RegexStringComparator("aa.*"));
  // optional
  setRowFilter(exampleFilter);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:13,代碼來源:TestTableInputFormat.java

示例10: createFilterFromArguments

public static Filter createFilterFromArguments(ArrayList<byte []> filterArguments) {
  Preconditions.checkArgument(filterArguments.size() == 4 || filterArguments.size() == 6,
                              "Expected 4 or 6 but got: %s", filterArguments.size());
  byte [] family = ParseFilter.removeQuotesFromByteArray(filterArguments.get(0));
  byte [] qualifier = ParseFilter.removeQuotesFromByteArray(filterArguments.get(1));
  CompareOp compareOp = ParseFilter.createCompareOp(filterArguments.get(2));
  ByteArrayComparable comparator = ParseFilter.createComparator(
    ParseFilter.removeQuotesFromByteArray(filterArguments.get(3)));

  if (comparator instanceof RegexStringComparator ||
      comparator instanceof SubstringComparator) {
    if (compareOp != CompareOp.EQUAL &&
        compareOp != CompareOp.NOT_EQUAL) {
      throw new IllegalArgumentException ("A regexstring comparator and substring comparator " +
                                          "can only be used with EQUAL and NOT_EQUAL");
    }
  }

  SingleColumnValueFilter filter = new SingleColumnValueFilter(family, qualifier,
                                                               compareOp, comparator);

  if (filterArguments.size() == 6) {
    boolean filterIfMissing = ParseFilter.convertByteArrayToBoolean(filterArguments.get(4));
    boolean latestVersionOnly = ParseFilter.convertByteArrayToBoolean(filterArguments.get(5));
    filter.setFilterIfMissing(filterIfMissing);
    filter.setLatestVersionOnly(latestVersionOnly);
  }
  return filter;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:29,代碼來源:SingleColumnValueFilter.java

示例11: testBulkDeleteWithConditionBasedDelete

public void testBulkDeleteWithConditionBasedDelete() throws Throwable {
  TableName tableName = TableName.valueOf("testBulkDeleteWithConditionBasedDelete");
  Table ht = createTable(tableName);
  List<Put> puts = new ArrayList<Put>(100);
  for (int j = 0; j < 100; j++) {
    byte[] rowkey = Bytes.toBytes(j);
    String value = (j % 10 == 0) ? "v1" : "v2";
    puts.add(createPut(rowkey, value));
  }
  ht.put(puts);
  Scan scan = new Scan();
  FilterList fl = new FilterList(Operator.MUST_PASS_ALL);
  SingleColumnValueFilter scvf = new SingleColumnValueFilter(FAMILY1, QUALIFIER3,
      CompareOp.EQUAL, Bytes.toBytes("v1"));
  // fl.addFilter(new FirstKeyOnlyFilter());
  fl.addFilter(scvf);
  scan.setFilter(fl);
  // Deleting all the rows where cf1:c1=v1
  long noOfRowsDeleted = invokeBulkDeleteProtocol(tableName, scan, 500, DeleteType.ROW, null);
  assertEquals(10, noOfRowsDeleted);

  int rows = 0;
  for (Result result : ht.getScanner(new Scan())) {
    rows++;
  }
  assertEquals(90, rows);
  ht.close();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:28,代碼來源:TestBulkDeleteProtocol.java

示例12: testToStringWithNullComparator

/**
 * Test for HBASE-8794. Avoid NullPointerException in DependentColumnFilter.toString().
 */
@Test
public void testToStringWithNullComparator() {
  // Test constructor that implicitly sets a null comparator
  Filter filter = new DependentColumnFilter(FAMILIES[0], QUALIFIER);
  assertNotNull(filter.toString());
  assertTrue("check string contains 'null' as compatator is null",
    filter.toString().contains("null"));

  // Test constructor with explicit null comparator
  filter = new DependentColumnFilter(FAMILIES[0], QUALIFIER, true, CompareOp.EQUAL, null);
  assertNotNull(filter.toString());
  assertTrue("check string contains 'null' as compatator is null",
    filter.toString().contains("null"));
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:17,代碼來源:TestDependentColumnFilter.java

示例13: testToStringWithNonNullComparator

@Test
public void testToStringWithNonNullComparator() {
  Filter filter =
      new DependentColumnFilter(FAMILIES[0], QUALIFIER, true, CompareOp.EQUAL,
          new BinaryComparator(MATCH_VAL));
  assertNotNull(filter.toString());
  assertTrue("check string contains comparator value", filter.toString().contains("match"));
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:8,代碼來源:TestDependentColumnFilter.java

示例14: setStopType

/**
 * Set end type for end value.
 * @param stopType - can only be LESS , LESS_OR_EQUAL or NO_OP
 */
public void setStopType(CompareOp stopType) {
  if (stopType == CompareOp.EQUAL || stopType == CompareOp.GREATER
      || stopType == CompareOp.GREATER_OR_EQUAL || stopType == CompareOp.NOT_EQUAL) {
    throw new IllegalArgumentException("Illegal end type: " + stopType.toString());
  }

  this.stopType = stopType;
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:12,代碼來源:Range.java

示例15: getRangeDistance

/**
 * Get the distance between a range's start value and its end value, represented by the percentage
 * of HRegions which a range spans in all the HRegions of the index table.
 * @param range
 * @return
 * @throws IOException-if index table has no region information
 */
public float getRangeDistance(Range range) throws IOException {
  if (range.getStartType() == CompareOp.EQUAL) {
    return -1.0f;
  }

  byte[] startKey = range.getStartValue();
  byte[] endKey = range.getEndValue();

  List<HRegionInfo> infos = indexRegionMaps.get(range.getColumn());
  if (infos == null || infos.size() == 0) {
    throw new IOException("Index table of " + Bytes.toString(range.getColumn())
        + " has no any HRegionInfo!");
  }

  int startRegion = 0;
  int endRegion = infos.size() - 1;

  for (int m = 0; m < infos.size(); m++) {
    HRegionInfo temp = infos.get(m);
    // TODO region start end key may be null
    if (startKey != null && startKey.length != 0) {
      if (temp.containsRow(startKey)) {
        startRegion = m;
      }
    }
    if (endKey != null && endKey.length != 0) {
      if (temp.containsRow(endKey)) {
        endRegion = m;
      }
    }
  }

  // regions between start region and end region (inclusive)
  int dis = (endRegion - startRegion - 1);

  // region percent between startKey and the region's endKey in the whole region
  float startdis = 1.0f;
  if (startKey != null) {
    startdis =
        1 - getByteArrayDistance(infos.get(startRegion).getStartKey(), infos.get(startRegion)
            .getEndKey(), startKey);
  }

  // region percent between endKey and the region's startKey in the whole region
  float enddis = 1.0f;
  if (endKey != null) {
    enddis =
        getByteArrayDistance(infos.get(endRegion).getStartKey(),
          infos.get(endRegion).getEndKey(), endKey);
  }

  return (dis + startdis + enddis) / infos.size();
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:60,代碼來源:SimpleIndexChooser.java


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