hbase java api最新版本_HBase基本命令与新版本Java API

简介

有关HBase的安装可以参考hbase安装

我们可以通过hbase shell和hbase数据库进行交互,也可以通过Java-api和hbase数据库交互,这里我们使用的是hbase-client。

主要是介绍2.0重大重构之后的api的基本使用。

9f18bdf12c27dd80b8e85d2718a84340.png

命名空间

#列出所有命名空间

list_namespace

#新建命名空间

create_namespace 'namespaceName'

#删除命名空间

drop_namespace 'namespaceName'

#修改命名空间

表操作

create:创建表

exists:检查表是否存在

list:查看所有表

alter:修改表

delete:删除列

disable:禁用表

is_enabled:查看表是否禁用

desc\describe:查看表结构

drop:删除表

put:插入数据

count:统计表有多少行

get:获取数据

scan:扫描表或者列

#列出所有表

list

#列出指定命名空间下的所有表

list_namespace_tables 'namespaceName'

#新建一个以命名空间namespaceName的表tableName,列族为cf1。

create 'namespaceName:tableName', 'cf1'

create 'tablename','columnFamily1','columnFamily2'

create 'tablename',{NAME => 'columnFamily1',VERSIONS => 1, TTL => 214783647, BLOCKCACHE => false,IN_MEMORY=>false},{NAME=>'columnFamily2',VERSIONS=>1,TTL=>259200,BLOCKCACHE=>false,IN_MEMORY=>false}

disable 'tableName'

#删除表

drop 'tableName'

#查看表内容,查看前5行数据

scan 'namespaceName:tableName', {LIMIT=>5}

#插入 put tableName rowkey,"columnFamily:column","value"

put 'tableName', 'rowkey', 'columnFamilyName:columnName', 'value'

#查看 get rowKey

get 'tableName', 'rowkey'

删除表中的列簇,先disable表,修改后enable表,严格区分大小写

scan

查询user表中的所有信息

scan 'user'

查询user表中列族为info的信息

scan 'user', {COLUMNS => 'info'}

scan 'user', {COLUMNS => 'info', RAW => true, VERSIONS => 5}

查询user表中列族为info和data的信息

scan 'user', {COLUMNS => ['info', 'data']}

scan 'user', {COLUMNS => ['info:name', 'data:pic']}

查询user表中列族为info、列标示符为name的信息

scan 'user', {COLUMNS => 'info:name'}

查询user表中列族为info、列标示符为name的信息,并且版本最新的5个

scan 'user', {COLUMNS => 'info:name', VERSIONS => 5}

查询user表中列族为info和data且列标示符中含有a字符的信息

scan 'user', {COLUMNS => ['info', 'data'], FILTER => "(QualifierFilter(=,'substring:a'))"}

查询user表中row key为rk0001,cell的值为中国

scan 'user', 'rk0001', {FILTER => "ValueFilter(=,'binary:中国')"}

查询user表中row key为rk0001,列标示符中含有a的信息

scan 'user', 'rk0001', {FILTER => "(QualifierFilter(=,'substring:a'))"}

查询user表中row key以rk字符开头的

scan 'user',{FILTER=>"PrefixFilter('rk')"}

查询user表中列族为info,rk范围是[rk0001, rk0003)的数据

scan 'user', {COLUMNS => 'info', STARTROW => 'rk0001', ENDROW => 'rk0003'}

查询user表中指定范围的数据

scan 'user', {TIMERANGE => [1392368783980, 1392380169184]}

get命令也可以使用如上所示的scan命令方式

基本命令

help:查看命令帮助

status:查看hbase状态

version:查看hbase版本

快照

修改表名HBase没有rename命令,可以通过快照功能修改表名

//为表创建快照,这时还没有复制数据

clone_snapshot 'tableSnapshot', 'newTableName'

//根据某个快照而创建新表,此时复制数据

snapshot 'tableName', 'tableSnapshot'

//删除快照

delete_snapshot 'tableSnapshot'

Java API

org.apache.hbase

hbase-client

2.2.0

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.Cell;

import org.apache.hadoop.hbase.HBaseConfiguration;

import org.apache.hadoop.hbase.NamespaceDescriptor;

import org.apache.hadoop.hbase.TableName;

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

import org.apache.hadoop.hbase.util.Bytes;

import org.junit.Before;

import org.junit.Test;

import java.io.IOException;

import java.util.LinkedList;

import java.util.List;

import java.util.Random;

public class HBaseTest {

private static final String ZOOKEEPER_QUORUM = "127.0.0.1:2181";

public static final String TABLE_NAME = "test_tb";

private Connection connection;

private Configuration configuration;

@Before

public void setUp() throws IOException {

configuration = HBaseConfiguration.create();

configuration.set("hbase.zookeeper.quorum", ZOOKEEPER_QUORUM);

connection = ConnectionFactory.createConnection(configuration);

}

@Test

public void createTable() throws Exception {

Admin admin = connection.getAdmin();

TableName tableName = TableName.valueOf(TABLE_NAME);

TableDescriptorBuilder tableDescriptorBuilder = TableDescriptorBuilder.newBuilder(tableName);

ColumnFamilyDescriptor baseInfo = ColumnFamilyDescriptorBuilder.of("base_info");

ColumnFamilyDescriptor extInfo = ColumnFamilyDescriptorBuilder.of("ext_info");

tableDescriptorBuilder.setColumnFamily(baseInfo);

tableDescriptorBuilder.setColumnFamily(extInfo);

TableDescriptor tableDescriptor = tableDescriptorBuilder.build();

admin.createTable(tableDescriptor);

}

@Test

public void dealTable() throws IOException {

Admin admin = connection.getAdmin();

String tableNameString = "test_user";

TableName tableName = TableName.valueOf(tableNameString);

if(admin.tableExists(tableName)){

admin.disableTable(tableName);

admin.deleteTable(tableName);

}

}

@Test

public void descTable() throws IOException {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

TableDescriptor tableDescriptor = table.getDescriptor();

ColumnFamilyDescriptor[] columnFamilies = tableDescriptor.getColumnFamilies();

for(ColumnFamilyDescriptor cfd : columnFamilies){

System.out.println(Bytes.toString(cfd.getName()));

}

}

@Test

public void put() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

Put put=new Put(Bytes.toBytes("user_info_1"));

// put.addColumn(Bytes.toBytes(familyName), Bytes.toBytes(columnName), Bytes.toBytes(value));

put.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("name"), Bytes.toBytes("tim"));

put.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("tel"), Bytes.toBytes("123"));

table.put(put);

}

@Test

public void puts() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

LinkedList puts = new LinkedList<>();

puts.add(getPut("user_info_2"));

puts.add(getPut("user_info_3"));

puts.add(getPut("user_info_4"));

table.put(puts);

}

private static Put getPut(String rowKey){

Put put=new Put(Bytes.toBytes(rowKey));

Random random = new Random();

String name = String.valueOf(random.nextInt(1000000));

put.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("name"), Bytes.toBytes(name));

put.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("tel"), Bytes.toBytes(name));

return put;

}

@Test

public void get() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

Get get =new Get(Bytes.toBytes("user_info_1"));

get.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("name"));

Result result=table.get(get);

List cells = result.listCells();

for(Cell cell: cells){

System.out.println(Bytes.toString(cell.getFamilyArray()));

System.out.println(Bytes.toString(cell.getQualifierArray()));

System.out.println(Bytes.toString(cell.getValueArray()));

System.out.println(cell.getTimestamp());

}

}

@Test

public void gets() throws IOException {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

LinkedList gets = new LinkedList<>();

gets.add(getGet("user_info_1"));

gets.add(getGet("user_info_2"));

gets.add(getGet("user_info_3"));

gets.add(getGet("user_info_4"));

Result[] results = table.get(gets);

for(Result result : results){

System.out.println(new String(result.getRow()));

System.out.println(new String(result.getValue(Bytes.toBytes("base_info"), Bytes.toBytes("name"))));

System.out.println(new String(result.getValue(Bytes.toBytes("base_info"), Bytes.toBytes("tel"))));

}

}

private static Get getGet(String rowKey){

Get get =new Get(Bytes.toBytes(rowKey));

get.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("name"));

get.addColumn(Bytes.toBytes("base_info"), Bytes.toBytes("tel"));

return get;

}

@Test

public void scan() throws IOException {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

Scan s = new Scan();

ResultScanner resultScanner = table.getScanner(s);

for(Result result : resultScanner){

byte[] row = result.getRow();

System.out.println(new String(row));

System.out.println(new String(result.getValue(Bytes.toBytes("base_info"), Bytes.toBytes("name"))));

}

}

@Test

public void deleteRowKey() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

Delete de =new Delete(Bytes.toBytes("rowKey"));

table.delete(de);

}

@Test

public void deleteColumn() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Table table = connection.getTable(tableName);

Delete de =new Delete(Bytes.toBytes("rowKey"));

de.addColumn(Bytes.toBytes(""), Bytes.toBytes(""));

table.delete(de);

}

@Test

public void disableTable() throws Exception {

TableName tableName = TableName.valueOf(TABLE_NAME);

Admin admin = connection.getAdmin();

admin.disableTable(tableName);

}

@Test

public void listNamespace() throws Exception {

Admin admin = connection.getAdmin();

NamespaceDescriptor[] namespaceDescriptors = admin.listNamespaceDescriptors();

for(NamespaceDescriptor namespaceDescriptor : namespaceDescriptors){

System.out.println(namespaceDescriptor.getName());

}

}

@Test

public void listTables() throws IOException {

Admin admin = connection.getAdmin();

List tableDescriptors = admin.listTableDescriptors();

for(TableDescriptor tableDescriptor : tableDescriptors){

System.out.println(tableDescriptor.getTableName().getNameAsString());

}

}

}

重点就是构建连接:

Configuration configuration = HBaseConfiguration.create();

configuration.set("hbase.zookeeper.quorum", "127.0.0.1:2181");

Connection connection = ConnectionFactory.createConnection(configuration);

相关的操作基本和Admin有关,通过Connection获取Admin:

Admin admin = connection.getAdmin();

不再使用字符串表明,而是使用TableName抽象:

TableName tableName = TableName.valueOf("tableName");

表描述构建:

TableDescriptorBuilder tableDescriptorBuilder = TableDescriptorBuilder.newBuilder(tableName);

列簇构建:

ColumnFamilyDescriptor baseInfo = ColumnFamilyDescriptorBuilder.of("base_info");

下面的createTable基本把表相关的抽象都使用到了:

@Test

public void createTable() throws Exception {

Admin admin = connection.getAdmin();

TableName tableName = TableName.valueOf(TABLE_NAME);

TableDescriptorBuilder tableDescriptorBuilder = TableDescriptorBuilder.newBuilder(tableName);

ColumnFamilyDescriptor baseInfo = ColumnFamilyDescriptorBuilder.of("base_info");

ColumnFamilyDescriptor extInfo = ColumnFamilyDescriptorBuilder.of("ext_info");

tableDescriptorBuilder.setColumnFamily(baseInfo);

tableDescriptorBuilder.setColumnFamily(extInfo);

TableDescriptor tableDescriptor = tableDescriptorBuilder.build();

admin.createTable(tableDescriptor);

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/500868.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java导致native非法指令,Java代码引起的NATIVE野指针问题(上)

朴英敏&#xff0c;小米MIUI部门。从事嵌入式开发和调试工作8年多&#xff0c;擅长逆向分析方法&#xff0c;主要负责解决安卓系统稳定性问题。上周音乐组同事反馈了一个必现Native Crash问题&#xff0c;tombstone如下&#xff1a; pid: 5028, tid: 5028, name: com.miui.play…

axure怎么做5秒倒计时_罗胖60秒:怎么做一个课程?

今天是罗胖陪伴你的第 2714 天1. 我们在研发课程的时候&#xff0c;有一个很关键的方法&#xff0c;我们内部称之为叫“不是而是”大法。2. 什么意思呢&#xff1f;就是如果你只告诉别人它是什么&#xff0c;那等于啥都没说。比如&#xff0c;我告诉你要经营好一家小店&#xf…

树莓派跑php,在树莓派4上部署nginx+php

本试验是基于树莓派的 buster 版本。一、安装 nginxapt install nginx -y完成安装之后&#xff0c;可以使用 dpkg -l | grep nginx 找到相关的安装包&#xff1a;通过分析 /var/lib/dpkg/status 可以得到 nginx 安装包的依赖关系&#xff1a;nginx --> nginx-full --> li…

php 如何生成微信小程序,微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载...

源码名称&#xff1a;微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载购买须知&#xff1a;(请仔细阅读了解)【1】源码一律经测试无误。【2】不提供任何修改和编辑服务&#xff0c;不包安装调试&#xff0c;假如你什么都不懂的请不要拍。【3】假…

java .item,javabb-javaitem-cloud

JavaItem-Cloud项目介绍JavaItem-Cloud是一个新开发的微服务架构平台&#xff0c;基于最新流行的技术SpringBoot、SpringCloud & SpringCloud Alibaba、Vue、Vuex、ElementUI。系统特性后端使用当前流行技术&#xff0c;SpringBoot、SpringCloud、SpringCloud Alibaba、Myb…

软件使用手册模板_我的印象笔记使用手册(精简说明)

在之前的一文中&#xff0c;我已经详细写过我的印象笔记使用的方法了&#xff0c;这次呢&#xff0c;再做一个更新的使用情况和更清楚明了和精简的说明。不居竹&#xff1a;我的印象笔记使用手册​zhuanlan.zhihu.com文章目录&#xff1a;1、知识管理收集知识整理知识输出知识2…

通信之道从微积分到5gpdf_保送清华成博士,华为12年搞通信,他为何如此看待 5G ?| 人物志...

作者 | 伍杏玲 胡巍巍出品 | CSDN(ID&#xff1a;CSDNnews)一位通信专家&#xff0c;清华读了博士&#xff0c;北大从事博士后研究工作&#xff0c;但却只有12年工作经历&#xff1f;明明家里几套房&#xff0c;却热爱骑车出行&#xff1f;他是&#xff1f;他是国内小有名气的通…

mysql封装 javabean,利用Java针对MySql封装的jdbc框架类JdbcUtils完整实现(包含增删改查、JavaBean反射原理,附源码)...

最近看老罗的视频&#xff0c;跟着完成了利用Java操作MySql数据库的一个框架类JdbcUtils.java,完成对数据库的增删改查。其中查询这块&#xff0c;包括普通的查询和利用反射完成的查询&#xff0c;主要包括以下几个函数接口:1、public Connection getConnection() 获得数据库的…

云计算的发展趋势_2020年的云计算发展趋势预测

点击上方“蓝色字体”&#xff0c;选择 “设为星标”关键讯息&#xff0c;D1时间送达&#xff01;SnapLogic公司首席技术官Craig Stewart表示&#xff0c;企业需要为不同的目的使用多个云平台&#xff0c;这将意味着多云应用的普及率将上升。在新的一年即将到来之际&#xff0c…

php x86什么意思,win10x86是什么意思

小编之前也是不知道x86是什么意思的&#xff0c;后来我的一个朋友给我好好的解释了一通我才明白。所以既然小编花了点时间才那个问题弄明白的&#xff0c;那接下来小编就来好好给你们说说x86是什么意思。小编最近发现有小伙伴在问x86是什么意思之类的问题&#xff0c;于是小编借…

php设置路径别名,react设置文件路径别名的具体方法你知道么

文章环境&#xff1a;“react”: “^16.13.1” 版本react官方脚手架默认是将webpack配置隐藏起来了&#xff0c;在进行配置之前需要将webpack给暴露出来。1、输入命令 npm run eject会出现一个命令提示&#xff1a;这是一个单向操作&#xff0c;确认操作后不可逆转/返回?输入 …

redis aof 备份和恢复_Redis 持久化机制的介绍,了解这些流程很重要

我们已经知道对于一个企业级的redis架构来说&#xff0c;持久化是不可减少的。企业级redis集群架构&#xff1a;海量数据、高并发、高可用持久化主要是做灾难恢复&#xff0c;数据恢复&#xff0c;也可以归类到高可用的一个环节里面去&#xff0c;比如你redis整个挂了&#xff…

最近公共祖先_leetcode No.236 二叉树的最近公共祖先

承接二叉搜索树的最近公共祖先。题目链接&#xff1a;二叉树的最近公共祖先 - 力扣&#xff08;LeetCode&#xff09;​leetcode-cn.com题目描述&#xff1a;给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T…

oracle连续周数,详细讲解Oracle数据库的“周数计算”

详细讲解Oracle数据库的“周数计算”以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;——日期计算 算第n周的第一天及最后一天是几号 by keynes—— ww的算法为每年 月 日为第一周开始 date …

php 命名空间通俗易懂_PHP进阶由浅入深掌握面向对象开发

视频教程出自黑马程序员PHP基础_由浅入深掌握面向对象开发【讲解方式】系统梳理和分解知识&#xff0c;各个点逐步讲解&#xff0c;由浅入深&#xff0c;通俗易懂&#xff0c;层层深入【课程亮点】1&#xff0c;已经完成PHP基础知识学习的朋友有帮助2&#xff0c;生动形象&…

linux直接用iso文件装服务,linux系统安装iso文件方法

摘要&#xff1a;linux系统下怎么安装iso文件&#xff1f;安装步骤&#xff1a;1、在&#xff0f;mnt目录下&#xff0c;创建相应的iso文件夹&#xff0c;例如iso。2、运行以下命令&#xff0c;挂载iso文...安装步骤&#xff1a;1、在&#xff0f;mnt目录下&#xff0c;创建相应…

深度linux支持安卓,深度操作系统 V20(1003)内测版招募:新增手机助手,支持安卓和 iOS 端,管理手机应用、文件...

IT之家9月28日消息 深度操作系统今天发布深度操作系统 20(1003)内测活动招募说明&#xff0c;IT之家获悉&#xff0c;本次操作系统将新增手机助手&#xff0c;支持安卓和iOS端&#xff0c;方便管理手机应用、文件等。更新说明&#xff1a;1、新增手机助手&#xff0c;支持安卓和…

选择排序(java)

选择排序 选择排序是默认前面都是已经排序好的&#xff0c;然后从后面 选择最小的放在前面排序好的的后面&#xff0c;首先第一轮循环的时候默认的排序好的为空&#xff0c;然后从后面选择最小的放到数组的第一个位置&#xff0c;第二轮循环的时候默认第个元素是已经 排序好的…

asp:dropdownlist如何去掉三角箭头_科目二倒库打轮早会压库角,教练9图详解如何快速调车避免压线?...

大家都知道&#xff0c;科目二考试五项中&#xff0c;最难的项目就是倒车入库。史教练在给科二学员指导时&#xff0c;总是强调&#xff0c;练车时不要只记死点。科目二考试过程瞬息万变&#xff0c;学员在倒库过程中&#xff0c;因为脚下离合没控制好&#xff0c;速度快了&…

linux以太网连接树莓派,如何在没有Internet的情况下直接连接到树莓派

描述Raspberry Pi的多功能性意味着您一定会在室外使用它&#xff0c;而这超出了无线网络的范围。那么&#xff0c;如何在不插入键盘和显示器的情况下与之通信呢&#xff1f;不言而喻&#xff0c;在不实际的情况下&#xff0c;要拖着人为输入设备并随身携带显示器。首先需要满足…