HBase Shell

$ ./bin/hbase shell   # 进入交互界面

DDL操作:

  1. create:创建表(默认命名空间为default)

    # create '表名','列族1','列族2'...
    hbase(main):005:0> create 'student','info'
    0 row(s) in 1.4250 seconds
    => Hbase::Table - student
  1. list:列出所有table

    hbase(main):005:0> list     # 列出所有的Table
    TABLE
    student
    1 row(s) in 0.0160 seconds
    => ["student"]
  2. describe '表名':查看表详细信息

    # 查看表详细信息describe
    hbase(main):007:0> describe 'student'
    Table student is ENABLED
    student
    COLUMN FAMILIES DESCRIPTION
    {NAME => 'info', BLOOMFILTER => 'ROW', VERSIONS => '', IN_MEMORY => 'false', KEEP_DELETED_CELLS => 'FALSE', DATA_BLOCK_ENCODING => 'NONE', TTL => 'FOREVER', COMPRESSION => 'NONE', MIN_VERSIONS => '', BLOCKCACHE => 'true', BLOCKSIZE => '', REPLICATION_SCOPE => ''}
    1 row(s) in 0.1090 seconds
    • NAME:列族名

    • BLOOMFILTER:布隆过滤器

    • VERSIONS:版本数,当前列族可以存多少版本

  3. alter:修改某列族的信息:

    # alter '表名',{NAME=>'列族名' ....}
    # 比如:修改VERSION版本数
    hbase(main):011:0> alter 'student',{NAME=>'info',VERSIONS=>3}
    hbase(main):012:0> describe 'student' # 再次查看
    {NAME => 'info', BLOOMFILTER => 'ROW', VERSIONS => '',....
  4. 删除表,需要先disabled

    # 删除表,需要先disabled,再drop
    hbase(main):016:0> disable 'student'
    hbase(main):017:0> drop 'student'

命名空间:

  1. 查看命名空间:list_namespace

    hbase(main):019:0> list_namespace
    NAMESPACE
    default
    hbase
    2 row(s) in 0.0330 seconds
  2. 创建命名空间:create_namespace '空间名'

    hbase(main):020:0> create_namespace 'bigdata'
  3. 创建表到指定命名空间

    hbase(main):022:0> create 'bigdata:student','info'
    0 row(s) in 2.2200 seconds
    => Hbase::Table - bigdata:student
  4. 删除命名空间:drop_namespace (必须是空的命名空间,要先删表)

    hbase(main):023:0> disable 'bigdata:student'
    0 row(s) in 2.2510 seconds
    hbase(main):024:0> drop 'bigdata:student'
    0 row(s) in 1.2370 seconds
    hbase(main):026:0> drop_namespace 'bigdata'
    0 row(s) in 0.8750 seconds

DML

  1. put:增加,修改数据

    # put '表名','RowKey','列族:列名','数据'
    hbase(main):030:0> put 'test','','info1:name','zhangsan'
  2. scan:扫描查询(最大范围是查整个table)

    # 注意:下面查询结果为3条数据
    hbase(main):040:0> scan 'test'
    ROW COLUMN+CELL
    1001 column=info1:age, timestamp=1571381227061, value=17
    1001 column=info1:name, timestamp=1571380877053, value=zhangsan
    1001 column=info2:addr, timestamp=1571381241065, value=shanghai
    1002 column=info1:age, timestamp=1571381266364, value=16
    1002 column=info1:name, timestamp=1571381256744, value=lily
    1002 column=info2:addr, timestamp=1571381276540, value=beijing
    1003 column=info2:addr, timestamp=1571381290769, value=nanjing
    3 row(s) in 0.0590 seconds
    # 查看,左闭右开区间
    hbase(main):044:0> scan 'test',{STARTROW=>'',ENDROW=>''}
    # 查看,覆盖的版本,已经type
    hbase(main):059:0> scan 'test',{RAW=>TRUE,VERSIONS=>3}
    ROW COLUMN+CELL
    1001 column=info1:age, timestamp=1571381227061, value=17
    1001 column=info1:name, timestamp=1571382287224, type=DeleteColumn
    1001 column=info1:name, timestamp=1571382179439, value=zhangsansan
    1001 column=info1:name, timestamp=1571382130052, value=zhang
    1001 column=info2:addr, timestamp=1571381241065, value=shanghai
    1002 column=info1:age, timestamp=1571381266364, value=16
    1002 column=info1:name, timestamp=1571381256744, value=lily
    1002 column=info2:addr, timestamp=1571381276540, value=beijing
    1003 column=info2:addr, timestamp=1571381290769, value=nanjing
  3. get:查询(最大范围是查RowKey)

    # 查看一条数据,一个RowKey
    hbase(main):041:0> get 'test',''
    COLUMN CELL
    info1:age timestamp=1571381227061, value=17
    info1:name timestamp=1571380877053, value=zhangsan
    info2:addr timestamp=1571381241065, value=shanghai
    1 row(s) in 0.0050 seconds
    # 查看某列
    hbase(main):042:0> get 'test','','info1:name'
    COLUMN CELL
    info1:name timestamp=1571380877053, value=zhangsan
  4. delete:删除数据,在shell命令中必须指定到列,API中可以指定到列族

    # 指定到列
    hbase(main):054:0> delete 'test','','info1:name'
  5. alter:变更表信息

    # 将info列族修改为可以存放3个版本
    hbase(main):004:0> alter 'stu',{NAME=>'info',VERSIONS=>3}
  6. 多版本查询

    hbase(main):007:0> get 'stu','',{COLUMN=>'info:name',VERSIONS=>3}
    COLUMN CELL
    info:name timestamp=1571383299883, value=lucy
    info:name timestamp=1571383293258, value=lily

【hbase】hbase的shell操作笔记的更多相关文章

  1. Hbase快速开始——shell操作

    一. 介绍 HBase是一个分布式的.面向列的开源数据库,源于google的一篇论文<bigtable:一个结构化数据的分布式存储系统>.HBase是Google Bigtable的开源实 ...

  2. HBase(四)HBase集群Shell操作

    一.进入HBase命令行 在你安装的随意台服务器节点上,执行命令:hbase shell,会进入到你的 hbase shell 客 户端 [admin@node21 ~]$ hbase shell S ...

  3. Hbase数据结构和shell操作

    Hbase的数据结构 基本要素:命名空间.表.行.列.单元格,region,时间戳. 1.命名空间:NameSpaces的作用 Table:表,所有的表都是命名空间的成员,即表必属于某个命名空间,如果 ...

  4. HBase学习之路 (三)HBase集群Shell操作

    进入HBase命令行 在你安装的随意台服务器节点上,执行命令:hbase shell,会进入到你的 hbase shell 客 户端 [hadoop@hadoop1 ~]$ hbase shell S ...

  5. Hbase(二)【shell操作】

    目录 一.基础操作 1.进入shell命令行 2.帮助查看命令 二.命名空间操作 1.创建namespace 2.查看namespace 3.删除命名空间 三.表操作 1.查看所有表 2.创建表 3. ...

  6. Hbase的常见shell操作

    1.带namespace的:https://blog.csdn.net/opensure/article/details/46470969 2.http://www.cnblogs.com/xing9 ...

  7. HBase学习笔记——配置及Shell操作

    1.HBase的配置 还是以前配置的集群,见:http://www.cnblogs.com/DarrenChan/p/6493373.html 我们约定:weekend03和weekend04放HMa ...

  8. Hbase之shell操作

    一. 介绍 HBase是一个分布式的.面向列的 开源数据库,源于google的一篇论文<bigtable:一个结构化数据的分布式存储系统>.HBase是Google Bigtable的开源 ...

  9. HBase(3)-安装与Shell操作

    一. 安装 1. 启动Zookeeper集群 2. 启动Hadoop集群 3. 上传并解压HBase -bin.tar.gz -C /opt/module 4. 修改配置文件 #修改habse-env ...

随机推荐

  1. 一秒解决CentOS下service 功能 不能使用 bash: service: command not found

    首先检查自己是否 使用的是root用户 如果是并且还不能用-----执行以下操作 在centos系统中,如果/sbin目录下没有service这个命令,就会出现 bash: service: comm ...

  2. Python - Django - AJAX 实现 POST 请求

    index.html: <input type="text" id="i1">+ <input type="text" i ...

  3. Excel四象限散点图的制作方法

    Excel中四象限散点图带文本数据标签,可以在散点图的基础上进行一些设置即可得到,无需第三方插件或者宏代码,非常方便,以office2013为例,效果如下: 步骤: 1.准备好数据源,选中两列数据源( ...

  4. [LeetCode] 282. Expression Add Operators 表达式增加操作符

    Given a string that contains only digits 0-9 and a target value, return all possibilities to add bin ...

  5. Redis 主从、哨兵Sentinel、Jedis

    Redis 主从.哨兵Sentinel.Jedis 2017年02月15日 15:52:48 有且仅有 阅读数 6183 文章标签: redis主从sentineljedis 更多 分类专栏: 7/1 ...

  6. powershell字符串操作

    字符串操作是powershell中重要的一项操作,学会使用字符串操作的一些常用方法会大大提高脚本编写效率,以下列出几个经常用到的字符串操作方法: 前提:本人的powershell版本是 1.字符串格式 ...

  7. 机器学习技法实现(一):AdaBoost- Decision Stump (AdaBoost - 决策树的基于Matlab的实现)

    经过前面对AdaBoost的总结,下面要基于Matlab实现AdaBoost-Stump进行二维平面数据点的分类的实验. 一. 实验原理 参看 http://blog.csdn.net/lg12591 ...

  8. Android中的算法

    算法是思想的体现形式,常见的算法做一些总结 算法简介 算法-Algorithm 解题方案的准确而完整的描述,是一系列解决问题的清晰指令 特征 有穷性,确切性,输入项,输出项,可行性 算法运算要素 算术 ...

  9. 面试之leetcode链表

    1 数组 (1)数组的插入 如果是插入到最后,那么不用移动O(1),如果插入位置在中间为O(n).所以最好O(1),最坏O(N),平均O(N),为了插入能达到O(1),插入O(1).引入了链表 2 链 ...

  10. odoo 流水码 编码规则

    <?xml version="1.0" encoding="utf-8"?> <odoo> <data noupdate=&quo ...