hbase:根据输入值分配 CompareFilter.CompareOp
hbase: assign CompareFilter.CompareOp based on input value
我们可以根据输入值取compareOperator值吗?例如,如果我的输入是 eq,那么它应该选择 CompareFilter.CompareOp.EQUAL
,否则如果输入是 ne,它应该选择 CompareFilter.CompareOp.NOT_EQUAL
.
类似于
if(input.equals("eq")) {
myCompareOp = EQUAL;
}else if(input.equals("ne")) {
myCompareOp = NOT_EQUAL;
}
SingleColumnValueFilter colValFilter = new SingleColumnValueFilter(Bytes.toBytes(<CF>), Bytes.toBytes(<CQ>)
, myCompareOp, new BinaryComparator(Bytes.toBytes(<value>)));
如有任何建议,我们将不胜感激
基于以上代码,是的,它会起作用。下面是示例代码片段,你可以看看 well.where ConditionType
是枚举...这样你也可以准备自己的枚举(如果条件也很好,则不是强制性的)
private Filter buildSimpleQuery(ConditionType ct, String name, Object value) {
name = super.getRealPropertyName(name);
validatePropertyValue(name, value);
Class<?> clazz = getPrimitiveFieldClass(name, value.getClass());
CompareOp compareOp = null;
boolean regexCompRequired = false;
switch (ct) {
case EQUALS:
compareOp = CompareOp.EQUAL;
regexCompRequired = String.class == clazz && value.toString().endsWith("*");
break;
case NOT_EQUALS:
compareOp = CompareOp.NOT_EQUAL;
regexCompRequired = String.class == clazz && value.toString().endsWith("*");
break;
case GREATER_THAN:
compareOp = CompareOp.GREATER;
break;
case GREATER_OR_EQUALS:
compareOp = CompareOp.GREATER_OR_EQUAL;
break;
case LESS_THAN:
compareOp = CompareOp.LESS;
break;
case LESS_OR_EQUALS:
compareOp = CompareOp.LESS_OR_EQUAL;
break;
default:
break;
}
String qualifier = name;
String theFamily = family != null ? family : familyMap.get(qualifier);
ByteArrayComparable byteArrayComparable = regexCompRequired
? new RegexStringComparator(value.toString().replace("*", "."))
: new BinaryComparator(value.toString().getBytes(StandardCharsets.UTF_8));
Filter query = new SingleColumnValueFilter(theFamily.getBytes(StandardCharsets.UTF_8),
qualifier.getBytes(StandardCharsets.UTF_8),
compareOp,
byteArrayComparable);
return query;
}
我们可以根据输入值取compareOperator值吗?例如,如果我的输入是 eq,那么它应该选择 CompareFilter.CompareOp.EQUAL
,否则如果输入是 ne,它应该选择 CompareFilter.CompareOp.NOT_EQUAL
.
类似于
if(input.equals("eq")) {
myCompareOp = EQUAL;
}else if(input.equals("ne")) {
myCompareOp = NOT_EQUAL;
}
SingleColumnValueFilter colValFilter = new SingleColumnValueFilter(Bytes.toBytes(<CF>), Bytes.toBytes(<CQ>)
, myCompareOp, new BinaryComparator(Bytes.toBytes(<value>)));
如有任何建议,我们将不胜感激
基于以上代码,是的,它会起作用。下面是示例代码片段,你可以看看 well.where ConditionType
是枚举...这样你也可以准备自己的枚举(如果条件也很好,则不是强制性的)
private Filter buildSimpleQuery(ConditionType ct, String name, Object value) {
name = super.getRealPropertyName(name);
validatePropertyValue(name, value);
Class<?> clazz = getPrimitiveFieldClass(name, value.getClass());
CompareOp compareOp = null;
boolean regexCompRequired = false;
switch (ct) {
case EQUALS:
compareOp = CompareOp.EQUAL;
regexCompRequired = String.class == clazz && value.toString().endsWith("*");
break;
case NOT_EQUALS:
compareOp = CompareOp.NOT_EQUAL;
regexCompRequired = String.class == clazz && value.toString().endsWith("*");
break;
case GREATER_THAN:
compareOp = CompareOp.GREATER;
break;
case GREATER_OR_EQUALS:
compareOp = CompareOp.GREATER_OR_EQUAL;
break;
case LESS_THAN:
compareOp = CompareOp.LESS;
break;
case LESS_OR_EQUALS:
compareOp = CompareOp.LESS_OR_EQUAL;
break;
default:
break;
}
String qualifier = name;
String theFamily = family != null ? family : familyMap.get(qualifier);
ByteArrayComparable byteArrayComparable = regexCompRequired
? new RegexStringComparator(value.toString().replace("*", "."))
: new BinaryComparator(value.toString().getBytes(StandardCharsets.UTF_8));
Filter query = new SingleColumnValueFilter(theFamily.getBytes(StandardCharsets.UTF_8),
qualifier.getBytes(StandardCharsets.UTF_8),
compareOp,
byteArrayComparable);
return query;
}