HBASE-11936 IsolationLevel must be attribute of a Query not a Scan (Vladimir Rodionov)
This commit is contained in:
parent
c95bf404b7
commit
d3bccd9b9e
|
@ -482,4 +482,10 @@ public class Get extends Query
|
||||||
public Get setReplicaId(int Id) {
|
public Get setReplicaId(int Id) {
|
||||||
return (Get) super.setReplicaId(Id);
|
return (Get) super.setReplicaId(Id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Get setIsolationLevel(IsolationLevel level) {
|
||||||
|
return (Get) super.setIsolationLevel(level);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,7 @@ import com.google.common.collect.ListMultimap;
|
||||||
@InterfaceAudience.Public
|
@InterfaceAudience.Public
|
||||||
@InterfaceStability.Evolving
|
@InterfaceStability.Evolving
|
||||||
public abstract class Query extends OperationWithAttributes {
|
public abstract class Query extends OperationWithAttributes {
|
||||||
|
private static final String ISOLATION_LEVEL = "_isolationlevel_";
|
||||||
protected Filter filter = null;
|
protected Filter filter = null;
|
||||||
protected int targetReplicaId = -1;
|
protected int targetReplicaId = -1;
|
||||||
protected Consistency consistency = Consistency.STRONG;
|
protected Consistency consistency = Consistency.STRONG;
|
||||||
|
@ -143,4 +144,31 @@ public abstract class Query extends OperationWithAttributes {
|
||||||
public int getReplicaId() {
|
public int getReplicaId() {
|
||||||
return this.targetReplicaId;
|
return this.targetReplicaId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set the isolation level for this query. If the
|
||||||
|
* isolation level is set to READ_UNCOMMITTED, then
|
||||||
|
* this query will return data from committed and
|
||||||
|
* uncommitted transactions. If the isolation level
|
||||||
|
* is set to READ_COMMITTED, then this query will return
|
||||||
|
* data from committed transactions only. If a isolation
|
||||||
|
* level is not explicitly set on a Query, then it
|
||||||
|
* is assumed to be READ_COMMITTED.
|
||||||
|
* @param level IsolationLevel for this query
|
||||||
|
*/
|
||||||
|
public Query setIsolationLevel(IsolationLevel level) {
|
||||||
|
setAttribute(ISOLATION_LEVEL, level.toBytes());
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* @return The isolation level of this query.
|
||||||
|
* If no isolation level was set for this query object,
|
||||||
|
* then it returns READ_COMMITTED.
|
||||||
|
* @return The IsolationLevel for this query
|
||||||
|
*/
|
||||||
|
public IsolationLevel getIsolationLevel() {
|
||||||
|
byte[] attr = getAttribute(ISOLATION_LEVEL);
|
||||||
|
return attr == null ? IsolationLevel.READ_COMMITTED :
|
||||||
|
IsolationLevel.fromBytes(attr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,6 @@ public class Scan extends Query {
|
||||||
private static final Log LOG = LogFactory.getLog(Scan.class);
|
private static final Log LOG = LogFactory.getLog(Scan.class);
|
||||||
|
|
||||||
private static final String RAW_ATTR = "_raw_";
|
private static final String RAW_ATTR = "_raw_";
|
||||||
private static final String ISOLATION_LEVEL = "_isolationlevel_";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* EXPERT ONLY.
|
* EXPERT ONLY.
|
||||||
|
@ -751,32 +750,7 @@ public class Scan extends Query {
|
||||||
return attr == null ? false : Bytes.toBoolean(attr);
|
return attr == null ? false : Bytes.toBoolean(attr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Set the isolation level for this scan. If the
|
|
||||||
* isolation level is set to READ_UNCOMMITTED, then
|
|
||||||
* this scan will return data from committed and
|
|
||||||
* uncommitted transactions. If the isolation level
|
|
||||||
* is set to READ_COMMITTED, then this scan will return
|
|
||||||
* data from committed transactions only. If a isolation
|
|
||||||
* level is not explicitly set on a Scan, then it
|
|
||||||
* is assumed to be READ_COMMITTED.
|
|
||||||
* @param level IsolationLevel for this scan
|
|
||||||
*/
|
|
||||||
public Scan setIsolationLevel(IsolationLevel level) {
|
|
||||||
setAttribute(ISOLATION_LEVEL, level.toBytes());
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
* @return The isolation level of this scan.
|
|
||||||
* If no isolation level was set for this scan object,
|
|
||||||
* then it returns READ_COMMITTED.
|
|
||||||
* @return The IsolationLevel for this scan
|
|
||||||
*/
|
|
||||||
public IsolationLevel getIsolationLevel() {
|
|
||||||
byte[] attr = getAttribute(ISOLATION_LEVEL);
|
|
||||||
return attr == null ? IsolationLevel.READ_COMMITTED :
|
|
||||||
IsolationLevel.fromBytes(attr);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set whether this scan is a small scan
|
* Set whether this scan is a small scan
|
||||||
|
@ -845,4 +819,10 @@ public class Scan extends Query {
|
||||||
public Scan setReplicaId(int Id) {
|
public Scan setReplicaId(int Id) {
|
||||||
return (Scan) super.setReplicaId(Id);
|
return (Scan) super.setReplicaId(Id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Scan setIsolationLevel(IsolationLevel level) {
|
||||||
|
return (Scan) super.setIsolationLevel(level);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue