HBase API

HBase API

4.1 环境准备

新建项目后在pom.xml中添加依赖:

<dependency>
    <groupId>org.apache.hbase</groupId>
    <artifactId>hbase-server</artifactId>
    <version>1.3.1</version>
</dependency>

<dependency>
    <groupId>org.apache.hbase</groupId>
    <artifactId>hbase-client</artifactId>
    <version>1.3.1</version>
</dependency>

4.2 DDL

创建HBase_DDL类
4.2.1 判断表是否存在
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.NamespaceDescriptor;
import org.apache.hadoop.hbase.NamespaceExistException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DDL {

//TODO 判断表是否存在
public static boolean isTableExist(String tableName) throws IOException {

    //1.创建配置信息并配置
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取与HBase的连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取DDL操作对象
    Admin admin = connection.getAdmin();

    //4.判断表是否存在操作
    boolean exists = admin.tableExists(TableName.valueOf(tableName));

    //5.关闭连接
    admin.close();
    connection.close();

    //6.返回结果
    return exists;
}

}
4.2.2 创建表
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.NamespaceDescriptor;
import org.apache.hadoop.hbase.NamespaceExistException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DDL {

//TODO 创建表
public static void createTable(String tableName, String... cfs) throws IOException {

    //1.判断是否存在列族信息
    if (cfs.length <= 0) {
        System.out.println("请设置列族信息!");
        return;
    }

    //2.判断表是否存在
    if (isTableExist(tableName)) {
        System.out.println("需要创建的表已存在!");
        return;
    }

    //3.创建配置信息并配置
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //4.获取与HBase的连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //5.获取DDL操作对象
    Admin admin = connection.getAdmin();

    //6.创建表描述器构造器
    TableDescriptorBuilder tableDescriptorBuilder = TableDescriptorBuilder.newBuilder(TableName.valueOf(tableName));

    //7.循环添加列族信息
    for (String cf : cfs) {
        ColumnFamilyDescriptorBuilder columnFamilyDescriptorBuilder = ColumnFamilyDescriptorBuilder.newBuilder(Bytes.toBytes(cf));
        tableDescriptorBuilder.setColumnFamily(columnFamilyDescriptorBuilder.build());
    }

    //8.执行创建表的操作
    admin.createTable(tableDescriptorBuilder.build());

    //9.关闭资源
    admin.close();
    connection.close();
}

}
4.2.3 删除表
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.NamespaceDescriptor;
import org.apache.hadoop.hbase.NamespaceExistException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DDL {

//TODO 删除表
public static void dropTable(String tableName) throws IOException {

    //1.判断表是否存在
    if (!isTableExist(tableName)) {
        System.out.println("需要删除的表不存在!");
        return;
    }

    //2.创建配置信息并配置
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //3.获取与HBase的连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //4.获取DDL操作对象
    Admin admin = connection.getAdmin();

    //5.使表下线
    TableName name = TableName.valueOf(tableName);
    admin.disableTable(name);

    //6.执行删除表操作
    admin.deleteTable(name);

    //7.关闭资源
    admin.close();
    connection.close();
}

}
4.2.4 创建命名空间
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.NamespaceDescriptor;
import org.apache.hadoop.hbase.NamespaceExistException;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DDL {

//TODO 创建命名空间
public static void createNameSpace(String ns) throws IOException {

    //1.创建配置信息并配置
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取与HBase的连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取DDL操作对象
    Admin admin = connection.getAdmin();

    //4.创建命名空间描述器
    NamespaceDescriptor namespaceDescriptor = NamespaceDescriptor.create(ns).build();

    //5.执行创建命名空间操作
    try {
        admin.createNamespace(namespaceDescriptor);
    } catch (NamespaceExistException e) {
        System.out.println("命名空间已存在!");
    } catch (Exception e) {
        e.printStackTrace();
    }

    //6.关闭连接
    admin.close();
    connection.close();

}

}

4.3 DML

创建类HBase_DML
4.3.1 插入数据
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DML {

//TODO 插入数据
public static void putData(String tableName, String rowKey, String cf, String cn, String value) throws IOException {

    //1.获取配置信息并设置连接参数
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取表的连接
    Table table = connection.getTable(TableName.valueOf(tableName));

    //4.创建Put对象
    Put put = new Put(Bytes.toBytes(rowKey));

    //5.放入数据
    put.addColumn(Bytes.toBytes(cf), Bytes.toBytes(cn), Bytes.toBytes(value));

    //6.执行插入数据操作
    table.put(put);

    //7.关闭连接
    table.close();
    connection.close();
}

}
4.3.2 单条数据查询
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DML {

//TODO 单条数据查询(GET)
public static void getDate(String tableName, String rowKey, String cf, String cn) throws IOException {

    //1.获取配置信息并设置连接参数
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取表的连接
    Table table = connection.getTable(TableName.valueOf(tableName));

    //4.创建Get对象
    Get get = new Get(Bytes.toBytes(rowKey));
    // 指定列族查询
    // get.addFamily(Bytes.toBytes(cf));
    // 指定列族:列查询
    // get.addColumn(Bytes.toBytes(cf), Bytes.toBytes(cn));

    //5.查询数据
    Result result = table.get(get);

    //6.解析result
    for (Cell cell : result.rawCells()) {
        System.out.println("CF:" + Bytes.toString(cell.getFamilyArray()) +
                ",CN:" + Bytes.toString(cell.getQualifierArray()) +
                ",Value:" + Bytes.toString(cell.getValueArray()));
    }

    //7.关闭连接
    table.close();
    connection.close();

}

}
4.3.3 扫描数据
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DML {

//TODO 扫描数据(Scan)
public static void scanTable(String tableName) throws IOException {

    //1.获取配置信息并设置连接参数
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取表的连接
    Table table = connection.getTable(TableName.valueOf(tableName));

    //4.创建Scan对象
    Scan scan = new Scan();

    //5.扫描数据
    ResultScanner results = table.getScanner(scan);

    //6.解析results
    for (Result result : results) {
        for (Cell cell : result.rawCells()) {
            System.out.println("CF:" + Bytes.toString(cell.getFamilyArray()) +
                    ",CN:" + Bytes.toString(cell.getQualifierArray()) +
                    ",Value:" + Bytes.toString(cell.getValueArray()));
        }
    }

    //7.关闭资源
    table.close();
    connection.close();

}

}
4.3.4 删除数据
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.Cell;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;

import java.io.IOException;

public class HBase_DML {

//TODO 删除数据
public static void deletaData(String tableName, String rowKey, String cf, String cn) throws IOException {

    //1.获取配置信息并设置连接参数
    Configuration configuration = HBaseConfiguration.create();
    configuration.set("hbase.zookeeper.quorum", "bigdata02,bigdata03,bigdata04");

    //2.获取连接
    Connection connection = ConnectionFactory.createConnection(configuration);

    //3.获取表的连接
    Table table = connection.getTable(TableName.valueOf(tableName));

    //4.创建Delete对象
    Delete delete = new Delete(Bytes.toBytes(rowKey));

    // 指定列族删除数据
    // delete.addFamily(Bytes.toBytes(cf));
    // 指定列族:列删除数据(所有版本)
    // delete.addColumn(Bytes.toBytes(cf), Bytes.toBytes(cn));
    // 指定列族:列删除数据(指定版本)
    // delete.addColumns(Bytes.toBytes(cf), Bytes.toBytes(cn));

    //5.执行删除数据操作
    table.delete(delete);

    //6.关闭资源
    table.close();
    connection.close();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值