精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網站建設資訊

NEWS

網站建設資訊

Java中怎么利用HBase實現客戶端編程

這篇文章將為大家詳細講解有關Java中怎么利用HBase實現客戶端編程,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

創新互聯專業為企業提供屏山網站建設、屏山做網站、屏山網站設計、屏山網站制作等企業網站建設、網頁設計與制作、屏山企業網站模板建站服務,十多年屏山做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。

1. 準備工作

  1. 下載后安裝jdk包(這里使用的是jdk-6u10-rc2-bin-b32-windows-i586-p-12_sep_2008);

  2. 下載eclipse,解壓到本地(這里使用的是eclipse-java-helios-SR2-win32);

  3. 下載HBase包,解壓安裝包到本地(這里使用的是hbase-0.90.2)。

2. 搭建開發環境

  1. 運行Eclipse,創建一個新的Java工程“HBaseClient”,右鍵項目根目錄,選擇 “Properties”->“Java Build  Path”->“Library”->“Add External  JARs”,將HBase解壓后根目錄下的hbase-0.90.2.jar、hbase-0.90.2-tests.jar和lib子目錄下所有jar  包添加到本工程的Classpath下。

  2. 按照步驟1中的操作,將自己所連接的HBase的配置文件hbase-site.xml添加到本工程的Classpath中,如下所示為配置文件的一個示例:

  3.   hbase.rootdir hdfs://hostname:9000/hbase   hbase.cluster.distributed true   hbase.zookeeper.quorum *.*.*.*, *.*.*.*, *.*.*.*   hbase.defaults.for.version 0.90.2  
  4. 下面可以在Eclipse環境下進行HBase編程了。

3. HBase基本操作代碼示例

3.1 初始化配置
private static Configuration conf = null; /**  * 初始化配置  */ static {     conf = HBaseConfiguration.create(); }
3.2 創建表
/**  * 創建表操作  * @throws IOException  */ public void createTable(String tablename, String[] cfs) throws IOException {     HBaseAdmin admin = new HBaseAdmin(conf);     if (admin.tableExists(tablename)) {         System.out.println("表已經存在!");     }     else {         HTableDescriptor tableDesc = new HTableDescriptor(tablename);         for (int i = 0; i < cfs.length; i++) {             tableDesc.addFamily(new HColumnDescriptor(cfs[i]));         }         admin.createTable(tableDesc);         System.out.println("表創建成功!");     } }
3.3 刪除表
/**  * 刪除表操作  * @param tablename  * @throws IOException  */ public void deleteTable(String tablename) throws IOException {     try {         HBaseAdmin admin = new HBaseAdmin(conf);         admin.disableTable(tablename);         admin.deleteTable(tablename);         System.out.println("表刪除成功!");     } catch (MasterNotRunningException e) {         e.printStackTrace();     } catch (ZooKeeperConnectionException e) {         e.printStackTrace();     } }
3.4 插入一行記錄
/**  * 插入一行記錄  * @param tablename  * @param cfs  */ public void writeRow(String tablename, String[] cfs) {     try {         HTable table = new HTable(conf, tablename);         Put put = new Put(Bytes.toBytes("rows1"));         for (int j = 0; j < cfs.length; j++) {             put.add(Bytes.toBytes(cfs[j]),                     Bytes.toBytes(String.valueOf(1)),                     Bytes.toBytes("value_1"));             table.put(put);         }     } catch (IOException e) {         e.printStackTrace();     } }
3.5 刪除一行記錄
/**  * 刪除一行記錄  * @param tablename  * @param rowkey  * @throws IOException  */ public void deleteRow(String tablename, String rowkey) throws IOException {     HTable table = new HTable(conf, tablename);     List list = new ArrayList();     Delete d1 = new Delete(rowkey.getBytes());     list.add(d1);     table.delete(list);     System.out.println("刪除行成功!"); }
3.6 查找一行記錄
/**  * 查找一行記錄  * @param tablename  * @param rowkey  */ public static void selectRow(String tablename, String rowKey)         throws IOException {     HTable table = new HTable(conf, tablename);     Get g = new Get(rowKey.getBytes());     Result rs = table.get(g);     for (KeyValue kv : rs.raw()) {         System.out.print(new String(kv.getRow()) + "  ");         System.out.print(new String(kv.getFamily()) + ":");         System.out.print(new String(kv.getQualifier()) + "  ");         System.out.print(kv.getTimestamp() + "  ");         System.out.println(new String(kv.getValue()));     } }
3.7 查詢表中所有行
/**  * 查詢表中所有行  * @param tablename  */ public void scaner(String tablename) {     try {         HTable table = new HTable(conf, tablename);         Scan s = new Scan();         ResultScanner rs = table.getScanner(s);         for (Result r : rs) {             KeyValue[] kv = r.raw();             for (int i = 0; i < kv.length; i++) {                 System.out.print(new String(kv[i].getRow()) + "  ");                 System.out.print(new String(kv[i].getFamily()) + ":");                 System.out.print(new String(kv[i].getQualifier()) + "  ");                 System.out.print(kv[i].getTimestamp() + "  ");                 System.out.println(new String(kv[i].getValue()));             }         }     } catch (IOException e) {         e.printStackTrace();     } }

關于Java中怎么利用HBase實現客戶端編程就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


網站名稱:Java中怎么利用HBase實現客戶端編程
本文網址:http://m.jcarcd.cn/article/iigsih.html
主站蜘蛛池模板: 日韩一三区免费影视 | 精品在线视频 | 国产愉拍99线观看 | 国产午夜手 | 国产不卡a | 日产精品一 | 午夜成人理论片 | 国产做爰一区二区 | 成人永久免费永久在 | 国产人兽在线 | 日韩免费在线观看 | 日韩福利精品 | 日韩高清第一页 | 精品在线第一页 | 国产绿奴09-01| 日韩精品欧美有码 | 日本精品三级在线看 | 国产自在线91 | 91香蕉在线 | 国产一区丝袜高 | 蜜桃视频在线观看 | 欧美日韩国产在线 | 国产视频动漫 | 午夜视频9999 | 午夜视频体内 | 国产网站91| 福利小视频在线观看 | 欧美亚洲日韩国产网 | 日韩中文在线字 | 日本aaa视频 | 国产精品制服高跟 | 国产精品强上在线 | 午夜免费时刻 | 片午夜在线观看 | 国产精品国产自线 | 国产老熟女狂 | 欧洲视频在线观看 | 精品视频在| 国产精品美女久 | 国产激情一区在线观 | 欧洲在线 |