HBase基础API(创建、插入、读取、扫描及删除)

一、添加Maven依赖

<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <version>4.12</version>
  <scope>test</scope>
</dependency>
<dependency>
  <groupId>org.apache.hbase</groupId>
  <artifactId>hbase-client</artifactId>
  <version>1.2.0</version>
</dependency>
<dependency>
  <groupId>org.apache.hbase</groupId>
  <artifactId>hbase-common</artifactId>
  <version>1.2.0</version>
</dependency>
<dependency>
  <groupId>org.apache.hbase</groupId>
  <artifactId>hbase-server</artifactId>
  <version>1.2.0</version>
</dependency>
<dependency>
  <groupId>org.apache.hadoop</groupId>
  <artifactId>hadoop-common</artifactId>
  <version>2.6.0</version>
</dependency>

二、创建表

创建表主要是通过HBase的Admin类来进行的,代码如下:

@Test
public void createTable() throws IOException {
    // 1、获取hbase连接,配置
    // hbase,zookeeper,property,clientPort
    Configuration conf = HBaseConfiguration.create();
    conf.set("hbase.zookeeper.quorum","hadoop4"); // 设置zookeeper地址,若是zookeeper集群,节点名称用逗号分隔
    conf.set("hbase.zookeeper.property.clientPort","2181"); // 设置zookeeper连接端口
    
    // 2、创建连接
    Connection conn = ConnectionFactory.createConnection(conf);

    // 3、创建admin(表管理类)
    Admin admin = conn.getAdmin();

    // 4、定义表名
    HTableDescriptor student = new HTableDescriptor(TableName.valueOf("student"));

    // 5、添加列簇信息
    student.addFamily(new HColumnDescriptor("info"));
    student.addFamily(new HColumnDescriptor("score"));

    // 6、调用创建表的方法进行建表操作
    admin.createTable(student);

    // 7、关闭连接
    admin.close();
    conn.close();
}

三、插入数据

插入通过HBase的Put类完成,代码如下:

@Test
public void putDataToTable() throws IOException {
   // 1、获取hbase连接,配置
   Configuration conf = HBaseConfiguration.create();
   conf.set("hbase.zookeeper.quorum","192.168.233.146");
   conf.set("hbase.zookeeper.property.clientPort","2181");

   // 2、创建连接
   Connection conn = ConnectionFactory.createConnection(conf);

   // 3、获取table
   Table student = conn.getTable(TableName.valueOf("student"));

   // 4、用行键实例化Put,行键为rk1
   Put put = new Put(Bytes.toBytes("rk1"));
   
   // 5、指定列族、列名和值,如:info:name zhangsan
   put.addColumn(Bytes.toBytes("info"),Bytes.toBytes("name"),Bytes.toBytes("zhangsan"));
   put.addColumn(Bytes.toBytes("info"),Bytes.toBytes("gender"),Bytes.toBytes("male"));
   put.addColumn(Bytes.toBytes("info"),Bytes.toBytes("age"),Bytes.toBytes("11"));

   // 6、执行Put,插入数据
   student.put(put);

   // 7、关闭连接
   student.close();
   conn.close();
}

四、读取数据

读取通过HBase的Get类完成,代码如下:

@Test
public void getDataFromTable() throws IOException {
    // 1、配置
    Configuration conf = HBaseConfiguration.create();
    conf.set("hbase.zookeeper.quorum","192.168.233.146");
    conf.set("hbase.zookeeper.property.clientPort","2181");

    // 2、连接
    Connection conn = ConnectionFactory.createConnection(conf);

    // 3、获取table
    Table student = conn.getTable(TableName.valueOf("student"));

    // 4、用行键实例化Get
    Get get = new Get(Bytes.toBytes("rk1"));
    // 指定列族和列名
    get.addColumn("info".getBytes(),"age".getBytes());

    // 5、读取结果
    Result result = student.get(get);

    // 6、对结果进行遍历
    Cell[] cells = result.rawCells();
    for (Cell cell : cells) {
        // 获取具体的值
        System.out.println("rowKey:"+Bytes.toString(CellUtil.cloneRow(cell)));
        System.out.println("列簇:"+Bytes.toString(CellUtil.cloneFamily(cell)));
        System.out.println("列名:"+Bytes.toString(CellUtil.cloneQualifier(cell)));
        System.out.println("value"+Bytes.toString(CellUtil.cloneValue(cell)));
    }

    // 7、关闭
    student.close;
    conn.close();
}

五、扫描数据

HBase读取数据有两种方式,一种是读取(Get),另一种是扫描(Scan),扫描针对的是某个行键范围

@Test
public void scanDataFromTable() throws IOException {
    // 1、配置
    Configuration conf = HBaseConfiguration.create();
    conf.set("hbase.zookeeper.quorum","192.168.233.146");
    conf.set("hbase.zookeeper.property.clientPort","2181");

    // 2、连接
    Connection conn = ConnectionFactory.createConnection(conf);

    // 3、获取table
    Table student = conn.getTable(TableName.valueOf("student"));

    // 4、初始化Scan实例
    Scan scan = new Scan();

    // 5、指定开始和结束的行键,即获取rk1~rk6之间的数据
    scan.setStartRow("rk1".getBytes());
    scan.setStopRow("rk6".getBytes());

    // 6、增加过滤条件,即指定列族和列名
    scan.addColumn("info".getBytes(),"age".getBytes());

    // 5、读取结果
    ResultScanner rs = student.getScanner(scan);

    // 6、对结果进行遍历
    for (Result r : rs) {
        Cell[] cells = r.rawCells();
        for (Cell cell : cells) {
            System.out.println("rowKey:"+Bytes.toString(CellUtil.cloneRow(cell)));
            System.out.println("列簇:"+Bytes.toString(CellUtil.cloneFamily(cell)));
            System.out.println("列名:"+Bytes.toString(CellUtil.cloneQualifier(cell)));
            System.out.println("value:"+Bytes.toString(CellUtil.cloneValue(cell)));
        }
    }
    
    // 7、关闭
    student.close();
    conn.close();
}

六、删除

需要注意的是删除表之前要先禁用表(disable)表

@Test
public void dropTable() throws IOException {
    //1、配置
    Configuration conf = HBaseConfiguration.create();
    conf.set("hbase.zookeeper.quorum","hadoop4");
    conf.set("hbase.zookeeper.property.clientPort","2181");

    //2、连接
    Connection conn = ConnectionFactory.createConnection(conf);

    //3、表管理类
    Admin admin = conn.getAdmin();

    //4、禁用表
    admin.disableTable(TableName.valueOf("student"));

    //5、删除表
    admin.deleteTable(TableName.valueOf("student"));

    //6、关闭资源
    admin.close();
    conn.close();
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值