真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

hbase2.0.2javaapi怎么用-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)hbase 2.0.2 java api怎么用,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

成都一家集口碑和實(shí)力的網(wǎng)站建設(shè)服務(wù)商,擁有專業(yè)的企業(yè)建站團(tuán)隊(duì)和靠譜的建站技術(shù),十載企業(yè)及個(gè)人網(wǎng)站建設(shè)經(jīng)驗(yàn) ,為成都近1000家客戶提供網(wǎng)頁(yè)設(shè)計(jì)制作,網(wǎng)站開發(fā),企業(yè)網(wǎng)站制作建設(shè)等服務(wù),包括成都營(yíng)銷型網(wǎng)站建設(shè),品牌網(wǎng)站制作,同時(shí)也為不同行業(yè)的客戶提供成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、外貿(mào)網(wǎng)站建設(shè)的服務(wù),包括成都電商型網(wǎng)站制作建設(shè),裝修行業(yè)網(wǎng)站制作建設(shè),傳統(tǒng)機(jī)械行業(yè)網(wǎng)站建設(shè),傳統(tǒng)農(nóng)業(yè)行業(yè)網(wǎng)站制作建設(shè)。在成都做網(wǎng)站,選網(wǎng)站制作建設(shè)服務(wù)商就選創(chuàng)新互聯(lián)。
package com.hbase.test;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CompareOperator;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Admin;
import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor;
import org.apache.hadoop.hbase.client.ColumnFamilyDescriptorBuilder;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.client.ResultScanner;
import org.apache.hadoop.hbase.client.Scan;
import org.apache.hadoop.hbase.client.Table;
import org.apache.hadoop.hbase.client.TableDescriptor;
import org.apache.hadoop.hbase.client.TableDescriptorBuilder;
import org.apache.hadoop.hbase.filter.ColumnPrefixFilter;
import org.apache.hadoop.hbase.filter.FilterList;
import org.apache.hadoop.hbase.filter.FilterList.Operator;
import org.apache.hadoop.hbase.filter.RegexStringComparator;
import org.apache.hadoop.hbase.filter.RowFilter;
import org.apache.hadoop.hbase.filter.SingleColumnValueFilter;
import org.apache.hadoop.hbase.util.Bytes;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
public class HbaseTest {
	
	Configuration conf = null;
	Connection conn = null;
	@Before
	public void getConfigAndConnection() {
		conf = HBaseConfiguration.create();
		conf.set("hbase.zookeeper.quorum", "bigdata01,bigdata02,bigdata03");
		conf.set("hbase.zookeeper.property.clientPort", "2181");
		try {
			conn = ConnectionFactory.createConnection(conf);
		} catch (IOException e) {
			e.printStackTrace();
		}		
	}
	@Test
	public void createTable() throws IOException {
			Admin admin = conn.getAdmin();
			if(!admin.isTableAvailable(TableName.valueOf("test"))) {
				TableName tableName = TableName.valueOf("test");
				//表描述器構(gòu)造器
				TableDescriptorBuilder  tdb  =TableDescriptorBuilder.newBuilder(tableName)  ;
				//列族描述起構(gòu)造器
				ColumnFamilyDescriptorBuilder cdb =  ColumnFamilyDescriptorBuilder.newBuilder(Bytes.toBytes("user"));
				//獲得列描述起
				ColumnFamilyDescriptor  cfd = cdb.build();
				//添加列族
				tdb.setColumnFamily(cfd);
				//獲得表描述器
				TableDescriptor td = tdb.build();
				//創(chuàng)建表
				//admin.addColumnFamily(tableName, cfd); //給標(biāo)添加列族
				admin.createTable(td);
			}
			//關(guān)閉鏈接
	}
	//單條插入
	@Test
	public void insertOneData() throws IOException {
		//new 一個(gè)列  ,hgs_000為row key
		Put put = new Put(Bytes.toBytes("hgs_000"));
		//下面三個(gè)分別為,列族,列名,列值
		put.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("name") , Bytes.toBytes("hgs"));
		TableName tableName = TableName.valueOf("test");
		//得到 table
		Table table = conn.getTable(tableName);
		//執(zhí)行插入
		table.put(put);				
	}
	//插入多個(gè)列
	@Test
	public void insertManyData() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		List puts = new ArrayList();
		Put put1 = new Put(Bytes.toBytes("hgs_001"));
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("name") , Bytes.toBytes("wd"));
		
		Put put2 = new Put(Bytes.toBytes("hgs_001"));
		put2.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("age") , Bytes.toBytes("25"));
		
		Put put3 = new Put(Bytes.toBytes("hgs_001"));
		put3.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("weight") , Bytes.toBytes("60kg"));
		
		Put put4 = new Put(Bytes.toBytes("hgs_001"));
		put4.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("sex") , Bytes.toBytes("男"));
		puts.add(put1);
		puts.add(put2);
		puts.add(put3);
		puts.add(put4);		
		table.put(puts);
		table.close();
}
	//同一條數(shù)據(jù)的插入
	@Test
	public void singleRowInsert() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		
		Put put1 = new Put(Bytes.toBytes("hgs_005"));
		
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("name") , Bytes.toBytes("cm"));		
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("age") , Bytes.toBytes("22"));		
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("weight") , Bytes.toBytes("88kg"));
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("sex") , Bytes.toBytes("男"));	
		
		table.put(put1);
		table.close();
	}
	//數(shù)據(jù)的更新,hbase對(duì)數(shù)據(jù)只有追加,沒有更新,但是查詢的時(shí)候會(huì)把最新的數(shù)據(jù)返回給哦我們
	@Test
	public void updateData() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Put put1 = new Put(Bytes.toBytes("hgs_002"));
		put1.addColumn(Bytes.toBytes("testfm"),Bytes.toBytes("weight") , Bytes.toBytes("63kg"));
		table.put(put1);
		table.close();
	}
	
	//刪除數(shù)據(jù)
	@Test
	public void deleteData() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		//參數(shù)為 row key
		//刪除一列
		Delete delete1 = new Delete(Bytes.toBytes("hgs_000"));
		delete1.addColumn(Bytes.toBytes("testfm"), Bytes.toBytes("weight"));
		//刪除多列
		Delete delete2 = new Delete(Bytes.toBytes("hgs_001"));
		delete2.addColumns(Bytes.toBytes("testfm"), Bytes.toBytes("age"));
		delete2.addColumns(Bytes.toBytes("testfm"), Bytes.toBytes("sex"));
		//刪除某一行的列族內(nèi)容
		Delete delete3 = new Delete(Bytes.toBytes("hgs_002"));
		delete3.addFamily(Bytes.toBytes("testfm"));
		
		//刪除一整行
		Delete delete4 = new Delete(Bytes.toBytes("hgs_003"));
		table.delete(delete1);
		table.delete(delete2);
		table.delete(delete3);
		table.delete(delete4);
		table.close();
	}
	
	//查詢
	//
	@Test
	public void querySingleRow() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		//獲得一行
		Get get = new Get(Bytes.toBytes("hgs_000"));
		Result set = table.get(get);
		Cell[] cells  = set.rawCells();
		for(Cell cell : cells) {
			System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
		                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
		}
		table.close();
		//Bytes.toInt(result.getValue(Bytes.toBytes("info"), Bytes.toBytes("password")))
		
	}
	//全表掃描
	@Test
	public void scanTable() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Scan scan = new Scan();
		//scan.addFamily(Bytes.toBytes("info"));
		//scan.addColumn(Bytes.toBytes("info"), Bytes.toBytes("password"));
		//scan.setStartRow(Bytes.toBytes("wangsf_0"));
		//scan.setStopRow(Bytes.toBytes("wangwu"));
		ResultScanner rsacn = table.getScanner(scan);
		for(Result rs:rsacn) {
			String rowkey = Bytes.toString(rs.getRow());
			System.out.println("row key :"+rowkey);
			Cell[] cells  = rs.rawCells();
			for(Cell cell : cells) {
				System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
			                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
			}
			System.out.println("-----------------------------------------");
		}
	}
	//過濾器
	
	@Test
	//列值過濾器
	public void singColumnFilter() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Scan scan = new Scan();
		//下列參數(shù)分別為,列族,列名,比較符號(hào),值
		SingleColumnValueFilter filter =  new SingleColumnValueFilter( Bytes.toBytes("testfm"),  Bytes.toBytes("name"),
                 CompareOperator.EQUAL,  Bytes.toBytes("wd")) ;
		scan.setFilter(filter);
		ResultScanner scanner = table.getScanner(scan);
		for(Result rs:scanner) {
			String rowkey = Bytes.toString(rs.getRow());
			System.out.println("row key :"+rowkey);
			Cell[] cells  = rs.rawCells();
			for(Cell cell : cells) {
				System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
			                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
			}
			System.out.println("-----------------------------------------");
		}
	}
	//row key過濾器
	@Test
	public void rowkeyFilter() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Scan scan = new Scan();
		RowFilter filter = new RowFilter(CompareOperator.EQUAL,new RegexStringComparator("^hgs_00*"));
		scan.setFilter(filter);
		ResultScanner scanner  = table.getScanner(scan);
		for(Result rs:scanner) {
			String rowkey = Bytes.toString(rs.getRow());
			System.out.println("row key :"+rowkey);
			Cell[] cells  = rs.rawCells();
			for(Cell cell : cells) {
				System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
			                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
			}
			System.out.println("-----------------------------------------");
		}
	}
	//列名前綴過濾器
	@Test
	public void columnPrefixFilter() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Scan scan = new Scan();
		ColumnPrefixFilter filter = new ColumnPrefixFilter(Bytes.toBytes("name"));
		scan.setFilter(filter);
		ResultScanner scanner  = table.getScanner(scan);
		for(Result rs:scanner) {
			String rowkey = Bytes.toString(rs.getRow());
			System.out.println("row key :"+rowkey);
			Cell[] cells  = rs.rawCells();
			for(Cell cell : cells) {
				System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
			                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
			}
			System.out.println("-----------------------------------------");
		}
	}
	
	//過濾器集合
	@Test
	public void FilterSet() throws IOException {
		Table table = conn.getTable(TableName.valueOf("test"));
		Scan scan = new Scan();
		FilterList list = new FilterList(Operator.MUST_PASS_ALL);
		SingleColumnValueFilter filter1 =  new SingleColumnValueFilter( Bytes.toBytes("testfm"),  Bytes.toBytes("age"),
                CompareOperator.GREATER,  Bytes.toBytes("23")) ;
		ColumnPrefixFilter filter2 = new ColumnPrefixFilter(Bytes.toBytes("weig"));
		list.addFilter(filter1);
		list.addFilter(filter2);
		
		scan.setFilter(list);
		ResultScanner scanner  = table.getScanner(scan);
		for(Result rs:scanner) {
			String rowkey = Bytes.toString(rs.getRow());
			System.out.println("row key :"+rowkey);
			Cell[] cells  = rs.rawCells();
			for(Cell cell : cells) {
				System.out.println(Bytes.toString(cell.getQualifierArray(), cell.getQualifierOffset(), cell.getQualifierLength())+"::"+
			                    Bytes.toString(cell.getValueArray(), cell.getValueOffset(), cell.getValueLength()));
			}
			System.out.println("-----------------------------------------");
		}
		
	}
	@After
	public void closeConn() throws IOException {
		conn.close();
	}
}	
	

關(guān)于“hbase 2.0.2 java api怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。


新聞標(biāo)題:hbase2.0.2javaapi怎么用-創(chuàng)新互聯(lián)
本文來源:http://weahome.cn/article/dpogos.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部