habse java api使用操作

上一篇cm5.4和cdh5.4安装(http://my.oschina.net/penngo/blog/517223),本文使用HBase的java客户端api操作Hbase。

需要用到的包可以在/opt/cloudera/parcels/CDH-5.4.7-1.cdh5.4.7.p0.3/jars找到,hbase版本1.0.0

habse java api使用操作_第1张图片

HbaseTest3.java代码例子

import java.io.IOException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.CellUtil;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.KeyValue;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.ZooKeeperConnectionException;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HBaseAdmin;
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.filter.BinaryPrefixComparator;
import org.apache.hadoop.hbase.filter.Filter;
import org.apache.hadoop.hbase.filter.RowFilter;
import org.apache.hadoop.hbase.filter.SingleColumnValueFilter;
import org.apache.hadoop.hbase.filter.CompareFilter.CompareOp;
import org.apache.hadoop.hbase.filter.SubstringComparator;
import org.apache.hadoop.hbase.filter.ValueFilter;
import org.apache.hadoop.hbase.util.Bytes;

public class HbaseTest3 {
	private Connection connection = null;

	public HbaseTest3() {

	}

	public void createTable(String tableName) {
		try {
			System.out.println("start create table ......");
			Connection con = this.getConnection();
			HBaseAdmin hBaseAdmin = (HBaseAdmin) con.getAdmin();
			if (hBaseAdmin.tableExists(tableName)) {// 如果存在要创建的表,那么先删除,再创建
				hBaseAdmin.disableTable(tableName);
				hBaseAdmin.deleteTable(tableName);
				System.out.println(tableName + " is exist,detele....");
			}

			HTableDescriptor tableDescriptor = new HTableDescriptor(
					TableName.valueOf(tableName));
			tableDescriptor.addFamily(new HColumnDescriptor("column1"));
			tableDescriptor.addFamily(new HColumnDescriptor("column2"));
			tableDescriptor.addFamily(new HColumnDescriptor("column3"));
			hBaseAdmin.createTable(tableDescriptor);
			System.out.println("create table success......");
		} catch (MasterNotRunningException e) {
			e.printStackTrace();
		} catch (ZooKeeperConnectionException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}

	}

	public void insertData(String tableName) {
		System.out.println("start insert data ......");

		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
			// HTablePool pool = new HTablePool(configuration, 1000);
			// HTable table = (HTable) pool.getTable(tableName);
			Put put = new Put("112233bbbcccc".getBytes());// 一个PUT代表一行数据,再NEW一个PUT表示第二行数据,每行一个唯一的ROWKEY,此处rowkey为put构造方法中传入的值
			put.addColumn("column1".getBytes(), null, "aaa2".getBytes());// 本行数据的第一列
			put.addColumn("column2".getBytes(), null, "bbb2".getBytes());// 本行数据的第三列
			put.addColumn("column3".getBytes(), null, "ccc2".getBytes());// 本行数据的第三列
			table.put(put);
			// pool.getTable(tableName).put(put);
		} catch (IOException e) {
			e.printStackTrace();
		}
		System.out.println("end insert data ......");
	}

	public void queryAll(String tableName) {
		// HTablePool pool = new HTablePool(configuration, 1000);
		// HTable table = (HTable) pool.getTable(tableName);
		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
			ResultScanner rs = table.getScanner(new Scan());
			for (Result r : rs) {
				System.out.println("获得到rowkey:" + new String(r.getRow()));
				for (KeyValue keyValue : r.raw()) {
					System.out.println("列:" + new String(keyValue.getFamily())
							+ "====值:" + new String(keyValue.getValue()));
				}
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	public void queryByCondition1(String tableName) {

		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
			Get scan = new Get("112233bbbcccc".getBytes());// 根据rowkey查询
			Result r = table.get(scan);
			System.out.println("获得到rowkey:" + new String(r.getRow()));
			for (KeyValue keyValue : r.raw()) {
				System.out.println("列:" + new String(keyValue.getFamily())
						+ "====值:" + new String(keyValue.getValue()));
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	public void queryByCondition2(String tableName) {

		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
			Filter filter = new SingleColumnValueFilter(
					Bytes.toBytes("column1"), null, CompareOp.EQUAL,
					Bytes.toBytes("aaa2")); // 当列column1的值为aaa时进行查询
			Scan s = new Scan();
			s.setFilter(filter);
			ResultScanner rs = table.getScanner(s);
			for (Result r : rs) {
				System.out.println("获得到rowkey:" + new String(r.getRow()));
				for (KeyValue keyValue : r.raw()) {
					System.out.println("列:" + new String(keyValue.getFamily())
							+ "====值:" + new String(keyValue.getValue()));
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}

	}

	public void queryByCondition3(String tableName) {
		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
//			提取rowkey以cccc结尾数据
//			Filter filter1 = new RowFilter(CompareOp.EQUAL,new RegexStringComparator(".*cccc$"));
//
//			提取rowkey以包含bbb的数据
//			Filter filter1 = new RowFilter(CompareOp.EQUAL,new SubstringComparator("bbb"));

//			提取rowkey以123开头的数据
			Filter filter1 = new RowFilter(CompareOp.EQUAL,new BinaryPrefixComparator("1122".getBytes()));

//			Filter filter1 = new RowFilter(CompareOp.EQUAL,
//					new BinaryComparator(Bytes.toBytes(rowkey)));

			Scan scan = new Scan();
			scan.setFilter(filter1);

			ResultScanner rs = table.getScanner(scan);
			for (Result r : rs) {
				System.out.println("获得到rowkey:" + new String(r.getRow()));
				for (Cell cell : r.rawCells()) {
					System.out.println("列:"
							+ new String(CellUtil.cloneFamily(cell)) + "====值:"
							+ new String(CellUtil.cloneValue(cell)));
				}
			}
			rs.close();

		} catch (Exception e) {
			e.printStackTrace();
		}

	}

	public void queryByCondition4(String tableName) {
		try {
			Connection con = this.getConnection();
			Table table = con.getTable(TableName.valueOf(tableName));
			Filter filter1 = new ValueFilter(CompareOp.EQUAL,
					new SubstringComparator("aaa2"));
			Scan scan = new Scan();
			scan.setFilter(filter1);

			ResultScanner rs = table.getScanner(scan);
			for (Result r : rs) {
				System.out.println("获得到rowkey:" + new String(r.getRow()));
				for (Cell cell : r.rawCells()) {
					System.out.println("列:"
							+ new String(CellUtil.cloneFamily(cell)) + "====值:"
							+ new String(CellUtil.cloneValue(cell)));
				}
			}
			rs.close();

		} catch (Exception e) {
			e.printStackTrace();
		}

	}

	public void close() throws IOException {
		if (connection != null) {
			connection.close();
		}
	}

	public Connection getConnection() throws IOException {
		Configuration configuration = HBaseConfiguration.create();
		configuration.set("hbase.zookeeper.property.clientPort", "2181");
		configuration.set("hbase.zookeeper.quorum", "192.168.17.108");
		if (connection == null) {
			connection = ConnectionFactory.createConnection(configuration);
		}
		return connection;
	}

	public static void main(String[] args) {
		HbaseTest3 hbaseTest = new HbaseTest3();
		try {
			String tableName = "test1";
			 hbaseTest.createTable("test1");
			 hbaseTest.insertData("test1");
			 hbaseTest.queryAll("test1");
			// hbaseTest.queryByCondition1(tableName);
//			 hbaseTest.queryByCondition2(tableName);
//			hbaseTest.queryByCondition3(tableName);
//			hbaseTest.queryByCondition4(tableName);
			hbaseTest.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}


运行结果:

habse java api使用操作_第2张图片

你可能感兴趣的:(habse java api使用操作)