生活随笔
收集整理的這篇文章主要介紹了
HBase-scan API 通过scan读取表中数据
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
直接貼代碼啦
[java]?view plaincopy
? ? ? ? ? ? ? ? ?? ????public?static?void?scanTable(String?zkIp,String?zkPort,String?tablename,String?startRow,String?stopRow)?throws?Exception?{?? ?????????? ????????HTablePool?pool;?? ????????Configuration?config?=?HBaseConfiguration.create();?? ????????config.set("hbase.zookeeper.quorum",zkIp);?? ????????config.set("hbase.zookeeper.property.clientPort",?zkPort);?? ????????pool?=?new?HTablePool(config,?2);?? ?????????? ????????HTableInterface?hbTable?=?null;?? ????????try?{?? ????????????hbTable?=?pool.getTable(tablename);??? ????????????ResultScanner?rs?=?null;?? ????????????Scan?scan?=?new?Scan();?? ?????????????? ????????????if?(startRow?!=?null)?{??? ????????????????scan.setStartRow(Bytes.toBytes(startRow));?? ????????????}?? ????????????if?(stopRow?!=?null)?{?? ????????????????scan.setStopRow(Bytes.toBytes(stopRow));?? ????????????}?? ?? ????????????rs?=?hbTable.getScanner(scan);?? ????????????hbTable.close();?? ????????????for?(Result?r?:?rs)?{?? ????????????????for?(KeyValue?kv?:?r.raw())?{?? ????????????????????StringBuffer?sb?=?new?StringBuffer()?? ????????????????????????????.append(Bytes.toString(kv.getRow())).append("\t")?? ????????????????????????????.append(Bytes.toString(kv.getFamily()))?? ????????????????????????????.append("\t")?? ????????????????????????????.append(Bytes.toString(kv.getQualifier()))?? ????????????????????????????.append("\t").append(Bytes.toString(kv.getValue()));?? ????????????????????System.out.println(sb.toString());?? ?????????????????????? ?????????????????????? ?????????????????????? ?????????????????????? ?? ????????????????}?? ?? ????????????}?? ?? ????????}?catch?(Exception?e)?{?? ????????????System.out.println(e.getMessage());?? ????????}finally{?? ????????????pool.close();?? ????????}?? ???????????? ????}??
總結
以上是生活随笔為你收集整理的HBase-scan API 通过scan读取表中数据的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。