我的hbase表是这样的:
hbase(main):040:0> scan 'TEST'
ROW COLUMN+CELL
4 column=data:108, timestamp=1399972960190, value=-240.0
4 column=data:112, timestamp=1399972960138, value=-160.0
4 column=data:12, timestamp=1399972922979, value=2
4 column=data:120, timestamp=1399972960124, value=-152.0
4 column=data:144, timestamp=1399972960171, value=-240.0
4 column=data:148, timestamp=1399972960152, value=-240.0
4 column=data:16, timestamp=1399972909606, value=9
4 column=data:8, timestamp=1399972917978, value=6
,其中所有的4s都是行id和108,112,12…限定符。我想从这个表TEST中随机获取三个限定符。
我可以获取所有限定符,但不能随机获取三个限定符。在java中有任何shell命令或API可以实现这一点吗?
如果只是获取前三行,请使用scan shell命令,并将LIMIT设置为3:
hbase(main):001:0> scan 'demo', {LIMIT => 3}
如果您希望使用Java API,请在ResultScanner上设置一个循环,该循环在第三次迭代后中断。很简单。
public static void main(String[] args) throws IOException {
Configuration conf = HBaseConfiguration.create();
HTable table = new HTable(conf, "demo");
Scan s = new Scan();
ResultScanner rs = table.getScanner(s);
int check = 0;
for(Result r : rs){
if(++check > 3)
break;
for (KeyValue kv : r.raw()){
System.out.println("Qualifier : " + Bytes.toString(kv.getQualifier()));
}
}
rs.close();
table.close();
}
}
如果您希望获得3个随机行,请使用RandomRowFilter与上述方法。
HTH