HBase学习2(HBase shell)
HBase 常用命令
查看当前用户:whoami
创建表:create '表名', '列族名1','列族名2','列族名N'
查看所有表:list
描述表: describe ‘表名’
判断表存在: exists '表名'
判断是否禁用启用表:is_enabled '表名'和is_disabled ‘表名’
添加记录: put ‘表名’, ‘rowKey’, ‘列族 : 列‘ , '值'
查看表中的记录总数: count '表名'
查看记录rowkey下的所有数据: get '表名' , 'rowKey'
获取某个列族:get '表名','rowkey','列族'
获取某个列族的某个列:get '表名','rowkey','列族:列’
删除记录:delete ‘表名’ ,‘行名’ , ‘列族:列'
删除整行:deleteall '表名','rowkey'
删除一张表:先要屏蔽该表,才能对该表进行删除
第一步 disable ‘表名’ ,第二步 drop '表名'
清空表:truncate '表名'
查看所有记录:scan "表名"
查看某个表某个列中所有数据: scan "表名" , {COLUMNS=>'列族名:列名'}
进入hbase shell
[root@spark1 ~]# start-hbase.sh #启动hbase
[root@spark1 ~]# hbase shell #
查询当前用户
hbase(main):024:0> whoami
查看有哪些表
hbase(main):020:0> list
表的管理
创建表
语法:create <table>, {NAME => <family>, VERSIONS => <VERSIONS>}
创建表t1,列族为f1,列族版本号为5
hbase(main):001:0> create 't1',{NAME=>'f1',VERSIONS=>5}
创建表t2,有两个family name:f1,f2,且版本数均为2
hbase(main):002:0> create 't2',{NAME => 'f1',VERSIONS => '2'},{NAME => 'f2',VERSINS => 2}
创建表t3
hbase(main):003:0> create 't3','f1','f2','f3'
创建表t4,将表依据分割算法HexStringSplit分布在15个Region里
hbase(main):004:0> create 't4','f1',{NUMREGIONS => 15,SPLITALGO => 'HexStringSplit'}
创建表t5,指定切分点
hbase(main):005:0> create 't5','f1',{SPLITS => ['10','20','30','40']}
创建表users
hbase(main):006:0> create 'users', 'user_id' ,'address','info'
=> Hbase::Table - users
向表t1中行row1,列f1:1,添加数据value1,时间戳为2016121730
hbase(main):007:0> put 't1','key1','f1:1','value1',2016121730
删除表(先屏蔽在删除)
hbase(main):008:0> disable 't1'
hbase(main):009:0> drop 't1'
查看表的结构
hbase(main):010:0> desc 't1'
表数据的增删改查
添加数据
语法:put <table>,<rowkey>,<family:column>,<value>,<timestamp>
给t1表添加条数据
hbase(main):011:0> put 't1','key1','f1:col1','value1'
查询某行记录
查询t1表中key1下所有的值
hbase(main):012:0> get 't1','key1'
查询t1 key1中,f1下1的值
hbase(main):013:0> get 't1','key1','f1:1'
或者
hbase(main):014:0> get 't1','key1',{COLUMN => 'f1:1'}
扫描表(可添加STARTROW、TIMERANGE和FITLER等高级功能)
hbase(main):015:0> scan 't1' ,{LIMIT => 5}
统计表中数据行数
语法:count <table>, {INTERVAL => intervalNum, CACHE => cacheNum}
INTERVAL设置多少行显示一次及对应的rowkey,默认1000;CACHE每次去取的缓存
区大小,默认是10,调整该参数可提高查询速度
查询表t1中的行数,每100条显示一次,缓存区为500
hbase(main):058:0> count 't1',{INTERVAL => 100,CACHE => 500}
删除数据
删除行中某个列值(必须指定列名)
例如:删除表t1,key1中的f1:1的数据
hbase(main):015:0> delete 't1','key1','f1:1'
删除行
hbase(main):016:0> deleteall 't1','key1'
删除表中所有数据
删除t1表中所有数据
hbase(main):017:0> truncate 't1'
权限管理
分配权限
语法 : grant <user> <permissions> <table> <column family> <column
qualifier>
查看权限
语法:user_permission <table>
收回权限
语法:revoke <user> <table> <column family> <column
qualifier>
Region管理
移动region
语法:move 'encodeRegionName', 'ServerName'
encodeRegionName指的regioName后面的编码,ServerName指的是master-stat
us的Region Servers列表
开启/关闭region
语法:balance_switch true|false
其他
查看命令帮助信息
hbase(main):020:0> create help
查看表是否存在
hbase(main):021:0> exists 't1'
HBase学习2(HBase shell)的更多相关文章
- Hbase 学习(一) hbase配置文件同步
最近在狂啃hadoop的书籍,这部<hbase:权威指南>就进入我的视野里面了,啃吧,因为是英文的书籍,有些个人理解不对的地方,欢迎各位拍砖. HDFS和Hbase配置同步 hbase的配 ...
- hbase 学习笔记二----shell
Hbase 是一个分布式的.面向列的开源数据库,其实现是建立在google 的bigTable 理论之上,并基于hadoop HDFS文件系统. Hbase不同于一般的关系型数据库 ...
- HBase 学习之一 <<HBase使用客户端API动态创建Hbase数据表并在Hbase下导出执行>>
HBase使用客户端API动态创建Hbase数据表并在Hbase下导出执行 ----首先感谢网络能够给我提供一个开放的学习平台,如果没有网上的技术爱好者提供 ...
- HBase学习——3.HBase表设计
1.建表高级属性 建表过程中常用的shell命令 1.1 BLOOMFILTER 默认是 NONE 是否使用布隆过虑及使用何种方式,布隆过滤可以每列族单独启用 使用HColumnDescriptor. ...
- HBase学习笔记-HBase性能研究(1)
使用Java API与HBase集群交互时,需要构建HTable对象,使用该对象提供的方法来进行插入/删除/查询等操作.要创建HTable对象,首先要创建一个带有HBase集群信息的配置对象Confi ...
- HBase学习——4.HBase过滤器
1.过滤器 基础API中的查询操作在面对大量数据的时候是非常苍白的,这里Hbase提供了高级的查询方法:Filter.Filter可以根据簇.列.版本等更多的条件来对数据进行过滤,基于Hbase本身提 ...
- HBase学习笔记之HBase原理和Shell使用
HBase学习指南之HBase原理和Shell使用 参考资料: 1.https://www.cnblogs.com/nexiyi/p/hbase_shell.html,hbase shell
- HBase学习之路 (三)HBase集群Shell操作
进入HBase命令行 在你安装的随意台服务器节点上,执行命令:hbase shell,会进入到你的 hbase shell 客 户端 [hadoop@hadoop1 ~]$ hbase shell S ...
- HBase学习笔记——配置及Shell操作
1.HBase的配置 还是以前配置的集群,见:http://www.cnblogs.com/DarrenChan/p/6493373.html 我们约定:weekend03和weekend04放HMa ...
随机推荐
- Android自动化测试工具之—UiAutomator环境配置
1.相关软件下载: 1)JDK: 1.6及其以上版本 2)Eclipse 3)Android SDK 其中Eclipse和Android SDK已经被Google打包成ADT(Android Deve ...
- Cocos2d-x Lua中帧动画
帧动画就是按一定时间间隔.一定的顺序.一帧一帧地显示帧图片.我们的美工要为精灵的运动绘制每一帧图片,因此帧动画会由很多帧组成,按照一定的顺序切换这些图片就可以了. 在Cocos2d-x Lua中播放帧 ...
- Session基础知识
Session基础知识 主题 概念 Session的创建 Session的存储机制 Session的失效 参考资料 概念 Session代表一次用户会话.一次用户会话的含义是:从客 ...
- GDI+的应用
在VS中创建窗体 (1)CDI+清除绘画面 在窗体中写入代码: protected override void OnPaint(PaintEventArgs e){ Graphics g=e.Grap ...
- python的文件处理学习笔记
python的文件处理函数是open() 以下主要是关于这个函数的一些学习笔记 1.文件处理离不开编码 要注意的是文件打开时的编码和文件保存时的编码的统一,这样才能保证你打开的文件不会存在乱码 总结: ...
- Django 路由系统(URL)
介绍 Django 1.11版本 URLConf官方文档 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表. 你就是以这种方式告 ...
- python下多线程的限制以及多进程中传递参数的方式
python多线程有个全局解释器锁(global interpreter lock),这个锁的意思是任一时间只能有一个线程使用解释器,跟单cpu跑多个程序一个意思,大家都是轮着用的,这叫“并发”,不是 ...
- Python利用subprocess起进程
from multiprocessing import Process, Pool import time import subprocess def task(msg): print 'hello, ...
- springboot添加对listener,servlet,filter的支持
比较常用的方式就是使用注解来添加对 监听器,过滤器,servlet的支持. 1.首先在启动类上添加 @ServletComponentScan 开启 对监听器,过滤器,servlet的注解扫描. ...
- ABAP重点各种接口技术
转自 http://www.cnblogs.com/penley/archive/2008/11/12/1332140.html 下面总结一下ABAP中的各种接口技术,因为学习时间不是很长,肯定还不全 ...