HBase详解(04) - HBase Java API使用

环境准备

新建Maven项目,在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 库表的操作

  • 创建HBase_DDL类

package com.zhangjk.HBase;

import org.apache.hadoop.conf.Configuration;

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.Connection;

import org.apache.hadoop.hbase.client.ConnectionFactory;

import org.junit.Test;

import java.io.IOException;

public
class HBase_DDL {

}

  • 判断表是否存在

//判断表是否存在

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;

}

@Test

public
void isTableExist()
throws IOException {

boolean b = isTableExist("student");

System.out.println(b);

}

  • 创建表

//创建表

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();

}

@Test

public
void createTable()
throws IOException {

createTable("student1","info1",
"info2");

}

  • 删除表

//删除表

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();

}

@Test

public
void dropTable()
throws IOException {

dropTable("student1");

}

  • 创建命名空间

//创建命名空间

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();

}

@Test

public
void createNameSpace()
throws IOException {

createNameSpace("test1");

}

DML 增删改查

  • 创建类HBase_DML
  • 插入数据

//插入数据

//tableName 表名

//rowKey 主键

//cf 列族名

//字段名称

//需要添加到值

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();

}

@Test

public
void putData()
throws IOException {

String tableName =
"student1";

String rowKey =
"001";

String cf =
"info1";

String cn =
"name";

String value =
"zhangshan";

putData(tableName, rowKey, cf, cn, value);

}

  • 单条数据查询(GET)

//单条数据查询(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();

}

@Test

public
void getDate()
throws IOException {

String tableName =
"student1";

String rowKey =
"001";

String cf =
"info1";

String cn =
"name";

getDate(tableName, rowKey, cf, cn);

}

  • 扫描数据(Scan)

//扫描数据(Scan)

public
static
void scanTable(String tableName)
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.创建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(

Bytes.toString(CellUtil.cloneRow(cell))+":"+

Bytes.toString(CellUtil.cloneFamily(cell))+":"
+

Bytes.toString(CellUtil.cloneQualifier(cell))
+":"
+

Bytes.toString(CellUtil.cloneValue(cell))

);

}

}

//7.关闭资源

table.close();

connection.close();

}

@Test

public
void scanTable()
throws IOException {

scanTable("student1");

}

  • 删除数据

//删除数据

public
static
void deletaData(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.创建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();

}

@Test

public
void deletaData()
throws IOException {

String tableName =
"student1";

String rowKey =
"001";

String cf =
"info1";

String cn =
"name";

deletaData(tableName, rowKey, cf, cn);

}

HBase详解(04) - HBase Java API使用的更多相关文章

  1. HBase详解(05) - HBase优化 整合Phoenix 集成Hive

    HBase详解(05) - HBase优化 整合Phoenix 集成Hive HBase优化 预分区 每一个region维护着startRow与endRowKey,如果加入的数据符合某个region维 ...

  2. kafka详解(03) - kafka JAVA API

    kafka详解(03) - kafka JAVA API Producer (生产者)API 消息发送流程 Kafka的Producer发送消息采用的是异步发送的方式.在消息发送的过程中,涉及到了两个 ...

  3. HBase详解(01) - Hbase简介

    HBase简介 定义:HBase是一种分布式.可扩展.支持海量数据存储的NoSQL数据库. 数据模型:逻辑上,HBase的数据模型同关系型数据库很类似,数据存储在一张表中,有行有列.但从HBase的底 ...

  4. HBase详解(03) - HBase架构和数据读写流程

    RegionServer 架构 每个RegionServer可以服务于多个Region 每个RegionServer中有多个Store, 1个WAL和1个BlockCache 每个Store对应一个列 ...

  5. [转帖]HBase详解(很全面)

    HBase详解(很全面) very long story 简单看了一遍 很多不明白的地方.. 2018-06-08 16:12:32 卢子墨 阅读数 34857更多 分类专栏: HBase   [转自 ...

  6. 图解大数据 | 海量数据库查询-Hive与HBase详解

    作者:韩信子@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/84 本文地址:http://www.showmeai.tech/article-det ...

  7. HBase详解(02) - HBase-2.0.5安装

    HBase详解(02) - HBase-2.0.5安装 HBase安装环境准备 Zookeeper安装 Zookeeper安装参考<Zookeeper详解(02) - zookeeper安装部署 ...

  8. Java网络编程和NIO详解开篇:Java网络编程基础

    Java网络编程和NIO详解开篇:Java网络编程基础 计算机网络编程基础 转自:https://mp.weixin.qq.com/s/XXMz5uAFSsPdg38bth2jAA 我们是幸运的,因为 ...

  9. Hadoop详解(04)-Hdfs

    Hadoop详解(04)-Hdfs HDFS概述 HDFS产出背景及定义 背景:随着数据量越来越大,在一个操作系统存不下所有的数据,那么就分配到更多的操作系统管理的磁盘中,但是不方便管理和维护,迫切需 ...

随机推荐

  1. 它让你1小时精通RabbitMQ消息队列(新增死信处理)

    支持.NET/.NET Framework/.NET Core RabbitMQ作为一款主流的消息队列工具早已广受欢迎.相比于其它的MQ工具,RabbitMQ支持的语言更多.功能更完善. 本文提供一种 ...

  2. Vue学习之--------Vue中过滤器(filters)的使用(代码实现)(2022/7/18)

    1.过滤器 1.1 概念 过滤器: 定义:对要显示的数据进行特定格式化后再显示(适用于一些简单逻辑的处理). 语法: 1.注册过滤器:Vue.filter(name,callback) 或 new V ...

  3. 再有人说synchronized是重量级锁,就把这篇文章扔给他看

    synchronized作为Java程序员最常用同步工具,很多人却对它的用法和实现原理一知半解,以至于还有不少人认为synchronized是重量级锁,性能较差,尽量少用. 但不可否认的是synchr ...

  4. 4.httprunner-参数化和数据驱动

    前言 参数化在config中使用parameters关键字 httprunner2.x 是在testsuite中实现参数化 httprunner3.x 是在testcase中的config实现参数化 ...

  5. 部署RAID 10

    额外添加4块硬盘,用于搭建RAID 10 检查linux的磁盘 [root@local-pyyu ~]# fdisk -l |grep '/dev/sd[a-z]' 磁盘 /dev/sda:21.5 ...

  6. 使用VsCode调试UE5的PuerTs

    使用VsCode调试UE5的PuerTs 1.下载测试的Demo项目 配置PuerTs的步骤这里不赘述. 2.准备工作 2.1 打开项目 正常来说,直接打开项目可以看到如下画面 如果直接点击运行,可以 ...

  7. Python基础之函数:2、globlal与nonlocal和闭包函数、装饰器、语法糖

    目录 一.global与nonlocal 1.global 2.nonlocal 二.函数名的多种用法 三.闭包函数 1.什么是闭包函数 2.闭包函数需满足的条件 3.闭包函数的作用 4.闭包函数的实 ...

  8. JS学习笔记 (四) 数组进阶

    1.基本知识 1.数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中的位置称为索引,以数字表示,以0开始. 2.数组是无类型的.数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的 ...

  9. Git配置和使用?Git你真的会用么?Git与SVN的主要区别

    1.Git环境配置    在学习Git之前,首先要知道什么是版本控制 1.1 版本控制:版本迭代.新的版本!版本管理器 版本控制是开发过程中用于管理我们的文件.目录或工程内容的修改内容,查看修改历史记 ...

  10. 基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理

    在工作流页面中,除了特定的业务表单信息外,往往也需要同时展示通用申请单的相关信息,因此在页面设计的时候需要使用一些组件化的概念来实现动态的内容展示处理,本篇随笔介绍Vue3+TypeScript+El ...