HBASE-19426 Move has() and setTimestamp() to Mutation (Chia-Ping Tsai)
Signed-off-by: Chia-Ping Tsai <chia7712@gmail.com>
This commit is contained in:
parent
db49391683
commit
c77778dd13
|
@ -17,19 +17,17 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hbase.client;
|
package org.apache.hadoop.hbase.client;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.CellUtil;
|
import org.apache.hadoop.hbase.CellUtil;
|
||||||
import org.apache.hadoop.hbase.KeyValue;
|
import org.apache.hadoop.hbase.KeyValue;
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.security.access.Permission;
|
import org.apache.hadoop.hbase.security.access.Permission;
|
||||||
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Performs Append operations on a single row.
|
* Performs Append operations on a single row.
|
||||||
|
@ -142,6 +140,12 @@ public class Append extends Mutation {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Append setTimestamp(long timestamp) {
|
||||||
|
super.setTimestamp(timestamp);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Append setAttribute(String name, byte[] value) {
|
public Append setAttribute(String name, byte[] value) {
|
||||||
return (Append) super.setAttribute(name, value);
|
return (Append) super.setAttribute(name, value);
|
||||||
|
|
|
@ -24,15 +24,14 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.CellUtil;
|
import org.apache.hadoop.hbase.CellUtil;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
import org.apache.hadoop.hbase.KeyValue;
|
import org.apache.hadoop.hbase.KeyValue;
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.security.access.Permission;
|
import org.apache.hadoop.hbase.security.access.Permission;
|
||||||
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to perform Delete operations on a single row.
|
* Used to perform Delete operations on a single row.
|
||||||
|
@ -294,26 +293,10 @@ public class Delete extends Mutation implements Comparable<Row> {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the timestamp of the delete.
|
|
||||||
*
|
|
||||||
* @param timestamp
|
|
||||||
*/
|
|
||||||
public Delete setTimestamp(long timestamp) {
|
|
||||||
if (timestamp < 0) {
|
|
||||||
throw new IllegalArgumentException("Timestamp cannot be negative. ts=" + timestamp);
|
|
||||||
}
|
|
||||||
this.ts = timestamp;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<String, Object> toMap(int maxCols) {
|
public Delete setTimestamp(long timestamp) {
|
||||||
// we start with the fingerprint map and build on top of it.
|
super.setTimestamp(timestamp);
|
||||||
Map<String, Object> map = super.toMap(maxCols);
|
return this;
|
||||||
// why is put not doing this?
|
|
||||||
map.put("ts", this.ts);
|
|
||||||
return map;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -24,16 +24,15 @@ import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.CellUtil;
|
import org.apache.hadoop.hbase.CellUtil;
|
||||||
import org.apache.hadoop.hbase.KeyValue;
|
import org.apache.hadoop.hbase.KeyValue;
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.io.TimeRange;
|
import org.apache.hadoop.hbase.io.TimeRange;
|
||||||
import org.apache.hadoop.hbase.security.access.Permission;
|
import org.apache.hadoop.hbase.security.access.Permission;
|
||||||
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
import org.apache.hadoop.hbase.util.ClassSize;
|
import org.apache.hadoop.hbase.util.ClassSize;
|
||||||
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to perform Increment operations on a single row.
|
* Used to perform Increment operations on a single row.
|
||||||
|
@ -151,7 +150,13 @@ public class Increment extends Mutation implements Comparable<Row> {
|
||||||
tr = new TimeRange(minStamp, maxStamp);
|
tr = new TimeRange(minStamp, maxStamp);
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Increment setTimestamp(long timestamp) {
|
||||||
|
super.setTimestamp(timestamp);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param returnResults True (default) if the increment operation should return the results. A
|
* @param returnResults True (default) if the increment operation should return the results. A
|
||||||
* client that is not interested in the result can save network bandwidth setting this
|
* client that is not interested in the result can save network bandwidth setting this
|
||||||
|
|
|
@ -28,7 +28,6 @@ import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.CellScannable;
|
import org.apache.hadoop.hbase.CellScannable;
|
||||||
import org.apache.hadoop.hbase.CellScanner;
|
import org.apache.hadoop.hbase.CellScanner;
|
||||||
|
@ -46,14 +45,15 @@ import org.apache.hadoop.hbase.security.access.AccessControlUtil;
|
||||||
import org.apache.hadoop.hbase.security.access.Permission;
|
import org.apache.hadoop.hbase.security.access.Permission;
|
||||||
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
||||||
import org.apache.hadoop.hbase.security.visibility.VisibilityConstants;
|
import org.apache.hadoop.hbase.security.visibility.VisibilityConstants;
|
||||||
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.hadoop.hbase.util.ClassSize;
|
||||||
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.shaded.com.google.common.collect.ArrayListMultimap;
|
import org.apache.hadoop.hbase.shaded.com.google.common.collect.ArrayListMultimap;
|
||||||
import org.apache.hadoop.hbase.shaded.com.google.common.collect.ListMultimap;
|
import org.apache.hadoop.hbase.shaded.com.google.common.collect.ListMultimap;
|
||||||
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteArrayDataInput;
|
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteArrayDataInput;
|
||||||
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteArrayDataOutput;
|
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteArrayDataOutput;
|
||||||
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteStreams;
|
import org.apache.hadoop.hbase.shaded.com.google.common.io.ByteStreams;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
|
||||||
import org.apache.hadoop.hbase.util.ClassSize;
|
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
|
||||||
|
|
||||||
@InterfaceAudience.Public
|
@InterfaceAudience.Public
|
||||||
public abstract class Mutation extends OperationWithAttributes implements Row, CellScannable,
|
public abstract class Mutation extends OperationWithAttributes implements Row, CellScannable,
|
||||||
|
@ -215,6 +215,7 @@ public abstract class Mutation extends OperationWithAttributes implements Row, C
|
||||||
if (getTTL() != Long.MAX_VALUE) {
|
if (getTTL() != Long.MAX_VALUE) {
|
||||||
map.put("ttl", getTTL());
|
map.put("ttl", getTTL());
|
||||||
}
|
}
|
||||||
|
map.put("ts", this.ts);
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -523,6 +524,153 @@ public abstract class Mutation extends OperationWithAttributes implements Row, C
|
||||||
return 0L;
|
return 0L;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the timestamp of the delete.
|
||||||
|
*/
|
||||||
|
public Mutation setTimestamp(long timestamp) {
|
||||||
|
if (timestamp < 0) {
|
||||||
|
throw new IllegalArgumentException("Timestamp cannot be negative. ts=" + timestamp);
|
||||||
|
}
|
||||||
|
this.ts = timestamp;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience method to determine if this object's familyMap contains
|
||||||
|
* a value assigned to the given family & qualifier.
|
||||||
|
* Both given arguments must match the KeyValue object to return true.
|
||||||
|
*
|
||||||
|
* @param family column family
|
||||||
|
* @param qualifier column qualifier
|
||||||
|
* @return returns true if the given family and qualifier already has an
|
||||||
|
* existing KeyValue object in the family map.
|
||||||
|
*/
|
||||||
|
public boolean has(byte [] family, byte [] qualifier) {
|
||||||
|
return has(family, qualifier, this.ts, HConstants.EMPTY_BYTE_ARRAY, true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience method to determine if this object's familyMap contains
|
||||||
|
* a value assigned to the given family, qualifier and timestamp.
|
||||||
|
* All 3 given arguments must match the KeyValue object to return true.
|
||||||
|
*
|
||||||
|
* @param family column family
|
||||||
|
* @param qualifier column qualifier
|
||||||
|
* @param ts timestamp
|
||||||
|
* @return returns true if the given family, qualifier and timestamp already has an
|
||||||
|
* existing KeyValue object in the family map.
|
||||||
|
*/
|
||||||
|
public boolean has(byte [] family, byte [] qualifier, long ts) {
|
||||||
|
return has(family, qualifier, ts, HConstants.EMPTY_BYTE_ARRAY, false, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience method to determine if this object's familyMap contains
|
||||||
|
* a value assigned to the given family, qualifier and timestamp.
|
||||||
|
* All 3 given arguments must match the KeyValue object to return true.
|
||||||
|
*
|
||||||
|
* @param family column family
|
||||||
|
* @param qualifier column qualifier
|
||||||
|
* @param value value to check
|
||||||
|
* @return returns true if the given family, qualifier and value already has an
|
||||||
|
* existing KeyValue object in the family map.
|
||||||
|
*/
|
||||||
|
public boolean has(byte [] family, byte [] qualifier, byte [] value) {
|
||||||
|
return has(family, qualifier, this.ts, value, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience method to determine if this object's familyMap contains
|
||||||
|
* the given value assigned to the given family, qualifier and timestamp.
|
||||||
|
* All 4 given arguments must match the KeyValue object to return true.
|
||||||
|
*
|
||||||
|
* @param family column family
|
||||||
|
* @param qualifier column qualifier
|
||||||
|
* @param ts timestamp
|
||||||
|
* @param value value to check
|
||||||
|
* @return returns true if the given family, qualifier timestamp and value
|
||||||
|
* already has an existing KeyValue object in the family map.
|
||||||
|
*/
|
||||||
|
public boolean has(byte [] family, byte [] qualifier, long ts, byte [] value) {
|
||||||
|
return has(family, qualifier, ts, value, false, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a list of all KeyValue objects with matching column family and qualifier.
|
||||||
|
*
|
||||||
|
* @param family column family
|
||||||
|
* @param qualifier column qualifier
|
||||||
|
* @return a list of KeyValue objects with the matching family and qualifier,
|
||||||
|
* returns an empty list if one doesn't exist for the given family.
|
||||||
|
*/
|
||||||
|
public List<Cell> get(byte[] family, byte[] qualifier) {
|
||||||
|
List<Cell> filteredList = new ArrayList<>();
|
||||||
|
for (Cell cell: getCellList(family)) {
|
||||||
|
if (CellUtil.matchingQualifier(cell, qualifier)) {
|
||||||
|
filteredList.add(cell);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return filteredList;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Private method to determine if this object's familyMap contains
|
||||||
|
* the given value assigned to the given family, qualifier and timestamp
|
||||||
|
* respecting the 2 boolean arguments
|
||||||
|
*
|
||||||
|
* @param family
|
||||||
|
* @param qualifier
|
||||||
|
* @param ts
|
||||||
|
* @param value
|
||||||
|
* @param ignoreTS
|
||||||
|
* @param ignoreValue
|
||||||
|
* @return returns true if the given family, qualifier timestamp and value
|
||||||
|
* already has an existing KeyValue object in the family map.
|
||||||
|
*/
|
||||||
|
protected boolean has(byte[] family, byte[] qualifier, long ts, byte[] value,
|
||||||
|
boolean ignoreTS, boolean ignoreValue) {
|
||||||
|
List<Cell> list = getCellList(family);
|
||||||
|
if (list.isEmpty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// Boolean analysis of ignoreTS/ignoreValue.
|
||||||
|
// T T => 2
|
||||||
|
// T F => 3 (first is always true)
|
||||||
|
// F T => 2
|
||||||
|
// F F => 1
|
||||||
|
if (!ignoreTS && !ignoreValue) {
|
||||||
|
for (Cell cell : list) {
|
||||||
|
if (CellUtil.matchingFamily(cell, family) &&
|
||||||
|
CellUtil.matchingQualifier(cell, qualifier) &&
|
||||||
|
CellUtil.matchingValue(cell, value) &&
|
||||||
|
cell.getTimestamp() == ts) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (ignoreValue && !ignoreTS) {
|
||||||
|
for (Cell cell : list) {
|
||||||
|
if (CellUtil.matchingFamily(cell, family) && CellUtil.matchingQualifier(cell, qualifier)
|
||||||
|
&& cell.getTimestamp() == ts) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (!ignoreValue && ignoreTS) {
|
||||||
|
for (Cell cell : list) {
|
||||||
|
if (CellUtil.matchingFamily(cell, family) && CellUtil.matchingQualifier(cell, qualifier)
|
||||||
|
&& CellUtil.matchingValue(cell, value)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (Cell cell : list) {
|
||||||
|
if (CellUtil.matchingFamily(cell, family) &&
|
||||||
|
CellUtil.matchingQualifier(cell, qualifier)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param row Row to check
|
* @param row Row to check
|
||||||
|
|
|
@ -27,18 +27,17 @@ import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.Cell;
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.CellUtil;
|
import org.apache.hadoop.hbase.CellUtil;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
import org.apache.hadoop.hbase.KeyValue;
|
|
||||||
import org.apache.hadoop.hbase.IndividualBytesFieldCell;
|
import org.apache.hadoop.hbase.IndividualBytesFieldCell;
|
||||||
|
import org.apache.hadoop.hbase.KeyValue;
|
||||||
import org.apache.hadoop.hbase.Tag;
|
import org.apache.hadoop.hbase.Tag;
|
||||||
import org.apache.yetus.audience.InterfaceAudience;
|
|
||||||
import org.apache.hadoop.hbase.io.HeapSize;
|
import org.apache.hadoop.hbase.io.HeapSize;
|
||||||
import org.apache.hadoop.hbase.security.access.Permission;
|
import org.apache.hadoop.hbase.security.access.Permission;
|
||||||
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
import org.apache.hadoop.hbase.security.visibility.CellVisibility;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.yetus.audience.InterfaceAudience;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to perform Put operations for a single row.
|
* Used to perform Put operations for a single row.
|
||||||
|
@ -326,141 +325,10 @@ public class Put extends Mutation implements HeapSize, Comparable<Row> {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
@Override
|
||||||
* A convenience method to determine if this object's familyMap contains
|
public Put setTimestamp(long timestamp) {
|
||||||
* a value assigned to the given family & qualifier.
|
super.setTimestamp(timestamp);
|
||||||
* Both given arguments must match the KeyValue object to return true.
|
return this;
|
||||||
*
|
|
||||||
* @param family column family
|
|
||||||
* @param qualifier column qualifier
|
|
||||||
* @return returns true if the given family and qualifier already has an
|
|
||||||
* existing KeyValue object in the family map.
|
|
||||||
*/
|
|
||||||
public boolean has(byte [] family, byte [] qualifier) {
|
|
||||||
return has(family, qualifier, this.ts, HConstants.EMPTY_BYTE_ARRAY, true, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A convenience method to determine if this object's familyMap contains
|
|
||||||
* a value assigned to the given family, qualifier and timestamp.
|
|
||||||
* All 3 given arguments must match the KeyValue object to return true.
|
|
||||||
*
|
|
||||||
* @param family column family
|
|
||||||
* @param qualifier column qualifier
|
|
||||||
* @param ts timestamp
|
|
||||||
* @return returns true if the given family, qualifier and timestamp already has an
|
|
||||||
* existing KeyValue object in the family map.
|
|
||||||
*/
|
|
||||||
public boolean has(byte [] family, byte [] qualifier, long ts) {
|
|
||||||
return has(family, qualifier, ts, HConstants.EMPTY_BYTE_ARRAY, false, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A convenience method to determine if this object's familyMap contains
|
|
||||||
* a value assigned to the given family, qualifier and timestamp.
|
|
||||||
* All 3 given arguments must match the KeyValue object to return true.
|
|
||||||
*
|
|
||||||
* @param family column family
|
|
||||||
* @param qualifier column qualifier
|
|
||||||
* @param value value to check
|
|
||||||
* @return returns true if the given family, qualifier and value already has an
|
|
||||||
* existing KeyValue object in the family map.
|
|
||||||
*/
|
|
||||||
public boolean has(byte [] family, byte [] qualifier, byte [] value) {
|
|
||||||
return has(family, qualifier, this.ts, value, true, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A convenience method to determine if this object's familyMap contains
|
|
||||||
* the given value assigned to the given family, qualifier and timestamp.
|
|
||||||
* All 4 given arguments must match the KeyValue object to return true.
|
|
||||||
*
|
|
||||||
* @param family column family
|
|
||||||
* @param qualifier column qualifier
|
|
||||||
* @param ts timestamp
|
|
||||||
* @param value value to check
|
|
||||||
* @return returns true if the given family, qualifier timestamp and value
|
|
||||||
* already has an existing KeyValue object in the family map.
|
|
||||||
*/
|
|
||||||
public boolean has(byte [] family, byte [] qualifier, long ts, byte [] value) {
|
|
||||||
return has(family, qualifier, ts, value, false, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Private method to determine if this object's familyMap contains
|
|
||||||
* the given value assigned to the given family, qualifier and timestamp
|
|
||||||
* respecting the 2 boolean arguments
|
|
||||||
*
|
|
||||||
* @param family
|
|
||||||
* @param qualifier
|
|
||||||
* @param ts
|
|
||||||
* @param value
|
|
||||||
* @param ignoreTS
|
|
||||||
* @param ignoreValue
|
|
||||||
* @return returns true if the given family, qualifier timestamp and value
|
|
||||||
* already has an existing KeyValue object in the family map.
|
|
||||||
*/
|
|
||||||
private boolean has(byte[] family, byte[] qualifier, long ts, byte[] value,
|
|
||||||
boolean ignoreTS, boolean ignoreValue) {
|
|
||||||
List<Cell> list = getCellList(family);
|
|
||||||
if (list.isEmpty()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
// Boolean analysis of ignoreTS/ignoreValue.
|
|
||||||
// T T => 2
|
|
||||||
// T F => 3 (first is always true)
|
|
||||||
// F T => 2
|
|
||||||
// F F => 1
|
|
||||||
if (!ignoreTS && !ignoreValue) {
|
|
||||||
for (Cell cell : list) {
|
|
||||||
if (CellUtil.matchingFamily(cell, family) &&
|
|
||||||
CellUtil.matchingQualifier(cell, qualifier) &&
|
|
||||||
CellUtil.matchingValue(cell, value) &&
|
|
||||||
cell.getTimestamp() == ts) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (ignoreValue && !ignoreTS) {
|
|
||||||
for (Cell cell : list) {
|
|
||||||
if (CellUtil.matchingFamily(cell, family) && CellUtil.matchingQualifier(cell, qualifier)
|
|
||||||
&& cell.getTimestamp() == ts) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (!ignoreValue && ignoreTS) {
|
|
||||||
for (Cell cell : list) {
|
|
||||||
if (CellUtil.matchingFamily(cell, family) && CellUtil.matchingQualifier(cell, qualifier)
|
|
||||||
&& CellUtil.matchingValue(cell, value)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (Cell cell : list) {
|
|
||||||
if (CellUtil.matchingFamily(cell, family) &&
|
|
||||||
CellUtil.matchingQualifier(cell, qualifier)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a list of all KeyValue objects with matching column family and qualifier.
|
|
||||||
*
|
|
||||||
* @param family column family
|
|
||||||
* @param qualifier column qualifier
|
|
||||||
* @return a list of KeyValue objects with the matching family and qualifier,
|
|
||||||
* returns an empty list if one doesn't exist for the given family.
|
|
||||||
*/
|
|
||||||
public List<Cell> get(byte[] family, byte[] qualifier) {
|
|
||||||
List<Cell> filteredList = new ArrayList<>();
|
|
||||||
for (Cell cell: getCellList(family)) {
|
|
||||||
if (CellUtil.matchingQualifier(cell, qualifier)) {
|
|
||||||
filteredList.add(cell);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return filteredList;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -117,7 +117,7 @@ public class HFileSystem extends FilterFileSystem {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Wrap a FileSystem object within a HFileSystem. The noChecksumFs and
|
* Wrap a FileSystem object within a HFileSystem. The noChecksumFs and
|
||||||
* writefs are both set to be the same specified fs.
|
* writefs are both set to be the same specified fs.
|
||||||
* Do not verify hbase-checksums while reading data from filesystem.
|
* Do not verify hbase-checksums while reading data from filesystem.
|
||||||
* @param fs Set the noChecksumFs and writeFs to this specified filesystem.
|
* @param fs Set the noChecksumFs and writeFs to this specified filesystem.
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue