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 ...
随机推荐
- 利用Google Analytics API实现自己的统计报表
Google Analytics 简称 GA,功能实在是太强大了,正因如此,导致调研GA API花费了大量的时间,太多的名词需要梳理. 正确的学习步骤是: 首先,找个有权限的账号,登录GA(https ...
- Django基础流程
软件环境: Pycharm 2018.1 Python 3.6 Django 2.0.3 1.新建项目 直接使用Pycharm的菜单来创建项目,命名为mysite. mysite mysite __i ...
- coursera 《现代操作系统》 -- 第九周 文件系统(1)
文件的定义 文件名-> 路径名 磁盘结构 磁臂转还是那根柱子转? 盘片被轴带动旋转,磁头读取经过的扇区的数据. 典型的磁盘结构 一块盘呢由若干个盘片组成 每个盘片呢实际上有两个面啊,两个盘面 每 ...
- Oracle数据库用户及表空间操作
//创建数据表空间 create tablespace test_data datafile '/u01/user_data.dbf' size 50m autoextend on next 50m ...
- DevExpress控件-lookupedit的使用方法详解(图文)转http://blog.csdn.net/qq395537505/article/details/50920508
绑定数据源: lookupedit.Properties.ValueMember = 实际要用的字段; //相当于editvalue lookupedit.Properties.DisplayMemb ...
- 自定义admin
平时我们用的django自带admin,怎么评价呢?一个字简陋,而且也人性化,如下图,首先只显示数据对象,如果要查看详细还有点进去,其次不能对自己想要的数据进行刷选 我们的期望是:数据如excel显示 ...
- Vue中获取dom元素
Vue.js虽然说是数据驱动页面的,但是有时候我们也要获取dom对象进行一些操作. vue的不同版本获取dom对象的方法不一样 Vue.js 1.0版本中,通过v-el绑定,然后通过this.els ...
- 我的Android进阶之旅------>修改Android签名证书keystore的密码、别名alias以及别名密码
转载于:http://blog.k-res.net/archives/1229.html 和 http://blog.k-res.net/archives/1671.html ADT允许自定义调试用 ...
- selenium 下载文件设置下载路径
Chrome 文件下载 Chrome浏览器类似,设置其options: download.default_directory:设置下载路径 profile.default_content_settin ...
- JavaScript四则运算计算器
直接上代码: 首先是HTML代码 <form> 第一个数字:<br> <input type="text" id="num1"&g ...