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 定时器Timer的使用
定时器有什么用 在我们Android客户端上有时候可能有些任务不是当时就执行,而是过了一个规定的时间在执行此次任务.那么这个时候定时器的作用就非常有用了.首先开启一个简单的定时器 Timer time ...
- 七牛上传ipa后自动生成plist文件
1.利用模板技术动态生成plist文件的内容:(模板内容和data替换为plist需要的内容) //artTemplate <script src="js/template.js&qu ...
- Python2.6升级Python2.7
Python2.6升级2.7 由于Centos6系列自带的python版本为2.6.6,然而有很多应用需要依赖于python2.7来实现,所以有了这个升级的需求.升级原理很简单,无非就是下载.编译.安 ...
- splay tree成段更新,成段查询poj3466
线段树入门题,换成splay tree 来搞搞. #include <stdio.h> #include <string.h> #include <algorithm&g ...
- 《从零开始学Swift》学习笔记(Day 53)——do-try-catch错误处理模式
原创文章,欢迎转载.转载请注明:关东升的博客 Swift 1.x的错误处理模式存在很多弊端,例如:为了在编程时候省事,给error参数传递一个nil,或者方法调用完成后不去判断error是否为nil, ...
- Cocos2d-x Lua中实例:帧动画使用
下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 帧动画实例 下面我们再看看具体的程序代码,首 ...
- Xtrabackup 使用方法
简介:Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品.本文测试使用的是1.3版本,X ...
- Windows下比较小巧的c/c++ ide
下载:codeblocks 只有几十兆. http://www.codeblocks.org/downloads/26#windows codeblocks-16.01mingw-nosetup.zi ...
- java integer String之equals vs ==
Integer a = new Integer(123); Integer b = new Integer(123); System.out.println(a == b); System.out.p ...
- 父标签浮动(float)“塌陷”问题
浮动“塌陷” float参见: http://www.cnblogs.com/bigtreei/p/8110090.html http://www.w3school.com.cn/css/css_po ...