HBase学习02(HBase API)

Posted 数据攻城小狮子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HBase学习02(HBase API)相关的知识,希望对你有一定的参考价值。

文章目录

环境准备

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

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

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

DDL

判断表是否存在

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;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;

后面的代码不再重复导包的代码

public class HBase_DDL01 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        System.out.println(HBase_DDL01.isTableExist("test01:student"));//true,因为这个表是存在的
    
    //TODO 判断表是否存在
    public static boolean isTableExist(String tableName) throws IOException 
        //1.创建配置信息并配置
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "hadoop102,hadoop103,hadoop104");
        //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;
    

创建表

public class HBase_DDL 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        HBase_DDL.createTable("test01:student","info");//因为此表已存在
        //所以输出:“需要创建的表已存在!”
    
    //TODO 判断表是否存在
    public static boolean isTableExist(String tableName) throws IOException 
        //1.创建配置信息并配置
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "hadoop102,hadoop103,hadoop104");
        //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;
    
    //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", "hadoop102,hadoop103,hadoop104");
        //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();
    

删除表

public class HBase_DDL 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        HBase_DDL.dropTable("sbtd");//随便写了一个不存在的表
        //输出“需要删除的表不存在!”
    
    //TODO 判断表是否存在
    public static boolean isTableExist(String tableName) throws IOException 
        //1.创建配置信息并配置
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "hadoop102,hadoop103,hadoop104");
        //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;
    
    //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", "hadoop102,hadoop103,hadoop104");
        //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();
    

创建命名空间

public class HBase_DDL 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        HBase_DDL.createNameSpace("test02");
    
    //TODO 创建命名空间
    public static void createNameSpace(String ns) throws IOException 
        //1.创建配置信息并配置
        Configuration configuration = HBaseConfiguration.create();
        configuration.set("hbase.zookeeper.quorum", "hadoop102,hadoop103,hadoop104");
        //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();
    

DML

插入数据

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.TableName;
import org.apache.hadoop.hbase.client.*;
import org.apache.hadoop.hbase.util.Bytes;
import java.io.IOException;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
public class HBase_DML 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        putData("test01:student","1003","info","name","Tom");
    

    //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", "hadoop102,hadoop103,hadoop104");
        //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();
    

单条数据查询

public class HBase_DML 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        getDate("test01:student","1002","info","name");
    

    //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", "hadoop102,hadoop103,hadoop104");
        //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("ROW:" + Bytes.toString(CellUtil.cloneRow(cell)) +
                    " CF:" + Bytes.toString(CellUtil.cloneFamily(cell))+
                    " CL:" + Bytes.toString(CellUtil.cloneQualifier(cell))+
                    " VALUE:" + Bytes.toString(CellUtil.cloneValue(cell)));
        
        //7.关闭连接
        table.close();
        connection.close();
    

扫描数据

public class HBase_DML 
    public static void main(String[] args) throws IOException 
        Logger.getLogger("org").setLevel(Level.ERROR);//去除无用INFO信息
        scanTable("test01:student");
    

    //TODO 扫描数据(Scan)
    public static void scanTable(String tableName) throws IOException 
        //1.获取配置信息并设置连接参数
        Configuration configuration = HBaseConfiguration.create(HBase学习02(HBase API)

HBase学习之路 HBase的API操作

大数据学习系列之三 ----- HBase Java Api 图文详解

HBase概念学习Java API之扫描和过滤器

hbase 批量插入api

hbase_学习_01_HBase环境搭建(单机)