1、hbase shell    进入hbase
[hadoop@mdw ~]$ hbase shell

HBase Shell; enter 'help<RETURN>' for list of supported commands.

Type "exit<RETURN>" to leave the HBase Shell

Version 0.94.16, r1557241, Fri Jan 10 20:10:24 UTC 2014

2、whoami    查看当前訪问hbase的用户
hbase(main):001:0> whoami
hadoop

3、version    查看当前hbase的版本号信息
hbase(main):002:0> version
0.94.16, r1557241, Fri Jan 10 20:10:24 UTC 2014

4、status    查看当前hbase的状态
hbase(main):003:0> status
2 servers, 0 dead, 1.0000 average load
也能够通过添加參数查看,status 'simple' 查看简单的信息、status 'summary' 查看概要信息、status 'detailed' 查看具体信息

5、create    创建表
hbase(main):007:0> create 'member','member_id','address','info'
0 row(s) in 1.1590 seconds


6、list    查看数据库中的表
hbase(main):008:0> list
TABLE                                                                                                    
member                                                                                                  
1 row(s) in 0.0280 seconds


7、describe 表名    查看表的信息
hbase(main):009:0>describe member
NameError: undefined local variable or method `member' for #<Object:0x453c47>
hbase(main):010:0> describe 'member'
DESCRIPTION                                                                                                                  ENABLED                            
 'member', {NAME => 'address', DATA_BLOCK_ENCODING => 'NONE', BLOOMF    true                                
 ILTER => 'NONE', REPLICATION_SCOPE => '0', VERSIONS => '3', COMPRES                                    
 SION => 'NONE', MIN_VERSIONS => '0', TTL => '2147483647', KEEP_DELE                                    
 TED_CELLS => 'false', BLOCKSIZE => '65536', IN_MEMORY => 'false', E                                    
 NCODE_ON_DISK => 'true', BLOCKCACHE => 'true'}, {NAME => 'info', DA                                    
 TA_BLOCK_ENCODING => 'NONE', BLOOMFILTER => 'NONE', REPLICATION_SCO                                    
 PE => '0', VERSIONS => '3', COMPRESSION => 'NONE', MIN_VERSIONS =>                                      
 '0', TTL => '2147483647', KEEP_DELETED_CELLS => 'false', BLOCKSIZE                                      
 => '65536', IN_MEMORY => 'false', ENCODE_ON_DISK => 'true', BLOCKCA                                    
 CHE => 'true'}, {NAME => 'member_id', DATA_BLOCK_ENCODING => 'NONE'                                    
 , BLOOMFILTER => 'NONE', REPLICATION_SCOPE => '0', VERSIONS => '3',                                    
  COMPRESSION => 'NONE', MIN_VERSIONS => '0', TTL => '2147483647', K                                    
 EEP_DELETED_CELLS => 'false', BLOCKSIZE => '65536', IN_MEMORY => 'f                                    
 alse', ENCODE_ON_DISK => 'true', BLOCKCACHE => 'true'}                                                  
1 row(s) in 0.0450 seconds
hbase(main):011:0>

8、删除列族
删除列族须要先禁用表,否则会报下面错误:
hbase(main):006:0> alter 'member',NAME=>'member_id',METHOD=>'delete'
ERROR: org.apache.hadoop.hbase.TableNotDisabledException: org.apache.hadoop.hbase.TableNotDisabledException: member
        at org.apache.hadoop.hbase.master.HMaster.checkTableModifiable(HMaster.java:1525)
        at org.apache.hadoop.hbase.master.handler.TableEventHandler.<init>(TableEventHandler.java:72)
        at org.apache.hadoop.hbase.master.handler.TableDeleteFamilyHandler.<init>(TableDeleteFamilyHandler.java:41)
        at org.apache.hadoop.hbase.master.HMaster.deleteColumn(HMaster.java:1430)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.apache.hadoop.hbase.ipc.WritableRpcEngine$Server.call(WritableRpcEngine.java:323)
        at org.apache.hadoop.hbase.ipc.HBaseServer$Handler.run(HBaseServer.java:1426)

删除列族的正确方法:
先禁用表:
hbase(main):007:0> disable 'member'
0 row(s) in 1.1690 seconds

然后删除列族(注意NAME和METHOD要大写):
hbase(main):008:0> alter 'member',NAME=>'member_id',METHOD=>'delete'
Updating all regions with the new schema...
1/1 regions updated.
Done.
0 row(s) in 1.1640 seconds

删除列族之后再启用表:
hbase(main):009:0> enable 'member'
0 row(s) in 1.2250 seconds

再次查看表信息,便能够发现member_id已经被删除
hbase(main):010:0>describe 'member'
DESCRIPTION                                                                                                                                                                                      
     ENABLED                                                    
 'member', {NAME => 'address', DATA_BLOCK_ENCODING => 'NONE', BLOOMFILTER => 'NONE', REPLICATION_SCOPE => '     true                
                                      
 0', VERSIONS => '3', COMPRESSION => 'NONE', MIN_VERSIONS => '0', TTL => '2147483647', KEEP_DELETED_CELLS =                                                           
 > 'false', BLOCKSIZE => '65536', IN_MEMORY => 'false', ENCODE_ON_DISK => 'true', BLOCKCACHE => 'true'}, {N                                                           
 AME => 'info', DATA_BLOCK_ENCODING => 'NONE', BLOOMFILTER => 'NONE', REPLICATION_SCOPE => '0', VERSIONS =>                        
                                   
  '3', COMPRESSION => 'NONE', MIN_VERSIONS => '0', TTL => '2147483647', KEEP_DELETED_CELLS => 'false', BLOC                                                           
 KSIZE => '65536', IN_MEMORY => 'false', ENCODE_ON_DISK => 'true', BLOCKCACHE => 'true'}                                                                              
1 row(s) in 0.0420 seconds


9、drop 表名    删除表
删除表时也须要先将表disable,否则会报错。为方便先创建个暂时表(user表)。然后将user表删除
hbase(main):019:0> create 'user','name','age' 
0 row(s) in 1.0900 seconds

没有禁用user表,直接删除,报下面错误:
hbase(main):020:0> drop 'user'
ERROR: Table user is enabled. Disable it first.'
Here is some help for this command:
Drop the named table. Table must first be disabled: e.g. "hbase> drop 't1'"

正确删除方法例如以下:
先禁用表:
hbase(main):021:0> disable 'user'
0 row(s) in 1.1660 seconds
然后删除表:
hbase(main):022:0> drop 'user'
0 row(s) in 1.0710 seconds
hbase(main):023:0> 

10、exists 表名    查看一个表是否存在
hbase(main):023:0> exists 'user'
Table user does not exist                                                                                
0 row(s) in 0.0230 seconds

hbase(main):024:0> exists 'member'
Table member does exist                                                                                  
0 row(s) in 0.0750 seconds

11、is_enabled    推断表是否enable
hbase(main):025:0> is_enabled 'member'
true                                                                                                    
0 row(s) in 0.0160 seconds

12、is_disabled    推断表是否disable
hbase(main):026:0> is_disabled 'member'
false                                                                                                    
0 row(s) in 0.0220 seconds

13、put    插入数据
hbase(main):076:0> put 'member','xueba','info:age','25'
0 row(s) in 0.0170 seconds

为了方便使用以下命令的,这里多插入一些数据:

put 'member','xueba','info:age','25'

put 'member','xueba','info:birthday','1989-06-19'

put 'member','xueba','info:company','tecent'

put 'member','xueba','address:contry','china'

put 'member','xueba','address:province','guangdong'

put 'member','xueba','address:city','shenzhen'

put 'member','xiaoming','info:age','24'

put 'member','xiaoming','info:birthday','1990-03-22'

put 'member','xiaoming','info:company','tecent'

put 'member','xiaoming','info:favorite','movie'

put 'member','xiaoming','address:contry','china'

put 'member','xiaoming','address:province','guangdong'

put 'member','xiaoming','address:city','guangzhou'

14、get    获取表数据
获取xueba的信息:
hbase(main):090:0> get 'member','xueba'
COLUMN                      CELL                                                                        
 address:city               timestamp=1436932081705, value=shenzhen                                      
 address:contry             timestamp=1436932081662, value=china                                        
 address:province           timestamp=1436932081686, value=guangdong                                    
 info:age                   timestamp=1436932081590, value=25                                            
 info:birthday              timestamp=1436932081619, value=1989-06-19                                    
 info:company               timestamp=1436932081642, value=tecent                                        
6 row(s) in 0.0080 seconds

获取xiaoming的info信息:
hbase(main):091:0> get 'member','xiaoming','info'
COLUMN                      CELL                                                                        
 info:age                   timestamp=1436932081724, value=24                                            
 info:birthday              timestamp=1436932081745, value=1990-03-22                                    
 info:company               timestamp=1436932081764, value=tecent                                        
 info:favorite              timestamp=1436932081784, value=movie                                        
4 row(s) in 0.0560 seconds

获取xiaoming的age信息
hbase(main):092:0> get 'member','xiaoming','info:age'
COLUMN                      CELL                                                                        
 info:age                   timestamp=1436932081724, value=24                                            
1 row(s) in 0.0060 seconds

15、put    更新记录
将xueba的age改为26:
hbase(main):093:0> put 'member','xueba','info:age','26'
0 row(s) in 0.0120 seconds
查看改动结果:
hbase(main):094:0> get 'member','xueba','info:age'
COLUMN                      CELL                                                                        
 info:age                   timestamp=1436932900139, value=26                                            
1 row(s) in 0.0070 seconds

16、通过timestamp获取数据
hbase(main):099:0> get 'member','xueba',{COLUMN=>'info:age',TIMESTAMP=>1436936294957}
COLUMN                      CELL                                                                        
 info:age                   timestamp=1436936294957, value=26                                            
1 row(s) in 0.0100 seconds

17、scan 表名    全表扫描
hbase(main):101:0> scan 'member'
ROW                         COLUMN+CELL                                                                  
 xiaoming                   column=address:city, timestamp=1436932131672, value=guangzhou                
 xiaoming                   column=address:contry, timestamp=1436932081802, value=china                  
 xiaoming                   column=address:province, timestamp=1436932081821, value=guangdong            
 xiaoming                   column=info:age, timestamp=1436932081724, value=24                          
 xiaoming                   column=info:birthday, timestamp=1436932081745, value=1990-03-22              
 xiaoming                   column=info:company, timestamp=1436932081764, value=tecent                  
 xiaoming                   column=info:favorite, timestamp=1436932081784, value=movie                  
 xueba                      column=address:city, timestamp=1436932081705, value=shenzhen                
 xueba                      column=address:contry, timestamp=1436932081662, value=china                  
 xueba                      column=address:province, timestamp=1436932081686, value=guangdong            
 xueba                      column=info:age, timestamp=1436936294957, value=26                          
 xueba                      column=info:birthday, timestamp=1436932081619, value=1989-06-19              
 xueba                      column=info:company, timestamp=1436932081642, value=tecent                  
2 row(s) in 0.0270 seconds
这里数据是2行,各自是xiaoming、xueba

18、delete    删除数据
删除xueba的age数据
hbase(main):102:0> delete 'member','xueba','info:age'
0 row(s) in 0.0400 seconds
删除后查看xueba信息,已没有age数据
hbase(main):103:0> get 'member','xueba'
COLUMN                      CELL                                                                        
 address:city               timestamp=1436932081705, value=shenzhen                                      
 address:contry             timestamp=1436932081662, value=china                                        
 address:province           timestamp=1436932081686, value=guangdong                                    
 info:birthday              timestamp=1436932081619, value=1989-06-19                                    
 info:company               timestamp=1436932081642, value=tecent                                        
5 row(s) in 0.0160 seconds

19、deleteall    删除整行
删除xiaoming的数据:
hbase(main):104:0> deleteall 'member','xiaoming'
0 row(s) in 0.0100 seconds
查看删除情况。能够看出已没有xiaoming的数据
hbase(main):105:0> get 'member','xiaoming'
COLUMN                      CELL                                                                        
0 row(s) in 0.0050 seconds

20、count 表名    查询表中总共同拥有多少行数据
hbase(main):106:0>count 'member'
1 row(s) in 0.0200 seconds
总共插入两行数据。上面将xiaoming的数据所有删除了。所以仅仅剩一行xueba的数据

21、truncate 表名    清空表
hbase(main):107:0> truncate 'member'
Truncating 'member' table (it may take a while):
 - Disabling table...
 - Dropping table...
 - Creating table...
0 row(s) in 3.2460 seconds
通过上面信息能够看出。清空表的操作是先禁用表,然后删除表,再又一次创建表




hbase经常使用的shell命令样例的更多相关文章

  1. hbase的常用的shell命令&hbase的DDL操作&hbase的DML操作

    前言 笔者在分类中的hbase栏目之前已经分享了hbase的安装以及一些常用的shell命令的使用,这里不仅仅重新复习一下shell命令,还会介绍hbase的DDL以及DML的相关操作. hbase的 ...

  2. Hbase_02、Hbase的常用的shell命令&Hbase的DDL操作&Hbase的DML操作(转)

    阅读目录 前言 一.hbase的shell操作 1.1启动hbase shell 1.2执行hbase shell的帮助文档 1.3退出hbase shell 1.4使用status命令查看hbase ...

  3. HBase介绍(4)---常用shell命令

    进入hbase shell console$HBASE_HOME/bin/hbase shell如果有kerberos认证,需要事先使用相应的keytab进行一下认证(使用kinit命令),认证成功之 ...

  4. shell 脚本样例

    1  解压文件,移动文件,删除特定目录 #!/bin/bash pa=$(cd ``; pwd) //获得当前目录的绝对路径 v_dir=${pa} mkdir ${v_dir} dirDist=${ ...

  5. CURL常用命令---样例

    原文地址: http://www.thegeekstuff.com/2012/04/curl-examples/ 下载单个文件,默认将输出打印到标准输出中(STDOUT)中 curl http://w ...

  6. shell脚本实例-菜单样例

    1.9.1 实例需求 用户在进行Linux系统管理的过程中,经常需要用到查看进程的信息.用户的信息等常用的功能.本例针对这一需求,使用shell编程实现基本的系统管理 功能.通过本程序,可以按照要求实 ...

  7. HBase Filter程序样例及Shell(图)

    ==过滤器执行流程== reset() : reset the filter state before filtering a new row. filterAllRemaining(): true ...

  8. HBase总结(二十)HBase经常使用shell命令具体说明

    进入hbase shell console $HBASE_HOME/bin/hbase shell 假设有kerberos认证,须要事先使用对应的keytab进行一下认证(使用kinit命令),认证成 ...

  9. Linux crontab 命令格式与具体样例

    基本格式 : * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用*或者 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 第4列表示 ...

随机推荐

  1. 错误/异常:java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind;的解决方法

    1.异常视图 2.解决方法   SocketException(JVM_Bind):套接口异常     说明:服务器端口号被占用 了  解决方法:点击 Window-->Preferences- ...

  2. 2018ACM/ICPC 青岛现场赛 E题 Plants vs. Zombies

    题意: 你的房子在0点,1,2,3,...,n(n<=1e5)点每个点都有一颗高度为0的花,浇一次水花会长a[i]. 你有一个机器人刚开始在你家,最多走m步,每一步只能往前走或者往后走,每走到一 ...

  3. java判断部署项目使用的服务器类型

    有两种方式 1.项目引入portal-kernel.jar.项目运行时使用 根据返回boolean值判断类型! 2.自己写java类 package webService.ZFGX.service; ...

  4. finall和set和构造方法的参数意义

    package demo04; /* * 形状 */public abstract class Shape { // 求周长 public abstract double getGrith(); // ...

  5. GMM实战

    一道作业题: https://www.kaggle.com/c/speechlab-aug03 就是给你训练集,验证集,要求用GMM(混合高斯模型)预测 测试集的分类,这是个2分类的问题. $ hea ...

  6. 怎么去除移动端点击a标签链接时的背景色

    在手机端点击链接时会发现有一个背景色,有时候需要改变这个颜色,或者去除这个颜色,有时候a标签做成按钮时这个颜色的存在会很丑,像这样: 可以通过 -webkit-tap-highlight-color: ...

  7. MarginTop 为何影响父元素的 MarginTop(转)

    add by zhj: 没找到原文 这个问题困惑了很久,虽然没有大碍早就摸出来怎么搞定它,但始终不明白原因出在哪里,如果只是IE有问题我也不会太在意,可问题是所有上等浏览器都表现如此,这样叫我怎能安心 ...

  8. 搭建基于MyEclipse的Hadoop开发环境

    不多说,直接上干货! 前面我们已经搭建了一个伪分布模式的Hadoop运行环境.请移步, hadoop-2.2.0.tar.gz的伪分布集群环境搭建(单节点) 我们绝大多数都习惯在Eclipse或MyE ...

  9. Git的一些常用命令

    一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 简单的说就是托管代码的便于多人开发的管理系统. 二.Git的一些命令,我详细的说一下 我是基于github给大家说一下git的一些常 ...

  10. KNN与SVM对比&SVM与逻辑回归的对比

    首先说一下两种学习方式: lazy learning  和  eager learning. 先说 eager learning, 这种学习方式是指在进行某种判断(例如,确定一个点的分类或者回归中确定 ...