进入Hbase Shell
1$HBASE_HOME/bin/hbase shell查看表
1hbase(main)> list查看表结构
123# 语法:describe <table># 例如:查看表t1的结构hbase(main)> describe 't1'创建表结构
123# 语法:create <table>, {NAME => <family>, VERSIONS => <VERSIONS>}# 例如:创建dashcam_rawlog表,并创建两个列族,名称为 tag 和 contentcreate 'dashcam_rawlog', 'content', 'tag'修改表结构
12345# 语法:alter 't1', {NAME => 'f1'}, {NAME => 'f2', METHOD => 'delete'},修改表结构必须先disable# 例如:修改表test1的cf的TTL为180天hbase(main)> disable 'test1'hbase(main)> alter 'test1',{NAME=>'body',TTL=>'15552000'},{NAME=>'meta', TTL=>'15552000'}hbase(main)> enable 'test1'查询数据
12345678910# 语法:scan <table>, {COLUMNS => [ <family:column>,.... ], LIMIT => num}# 另外,还可以添加STARTROW、TIMERANGE和FITLER等高级功能# 例如:扫描表t1的前5条数据hbase(main)> scan 't1',{LIMIT=>5}# 扫描所有dashcam_rawlog的所有行,慎用scan 'dashcam_rawlog'# 获取rowkey为\xEF\xAB\x37的行,注意,一定要用双引号来扩起rowkey!!!get 'dashcam_rawlog', "\xEF\xAB\x37"删除表
1234# 两步:首先disable,然后drop# 例如:删除表t1hbase(main)> disable 't1'hbase(main)> drop 't1'更改TTL
123disable 'dashcam_host'alter 'dashcam_host', NAME=>'hostinfo', TTL=>'604800'enable 'dashcam_host'添加数据
1234# 语法:put <table>,<rowkey>,<family:column>,<value>,<timestamp># 例如:给表t1的添加一行记录:rowkey是rowkey001,family name:f1,column name:col1,value:value01,timestamp:系统默认hbase(main)> put 't1','rowkey001','f1:col1','value01'用法比较单一。删除数据
123456789# a.删除行中的某个列值# 语法:delete <table>, <rowkey>, <family:column> , <timestamp>,必须指定列名# 例如:删除表t1,rowkey001中的f1:col1的数据hbase(main)> delete 't1','rowkey001','f1:col1'# b.删除整行(所有版本数据)# 语法:deleteall <table>, <rowkey>, <family:column> , <timestamp>,可以不指定列名,删除整行数据# 例如:删除表t1,rowk001的数据hbase(main)> deleteall 't1','rowkey001'清空表数据
123# 语法: truncate <table># 其具体过程是:disable table -> drop table -> create table# 例如:删除表t1的所有数据hbase(main)> truncate 't1'查询表中数据行数
1234# 语法:count <table>, {INTERVAL => intervalNum, CACHE => cacheNum}# INTERVAL设置多少行显示一次及对应的rowkey,默认1000;CACHE每次去取的缓存区大小,默认是10,调整该参数可提高查询速度# 例如,查询表t1中的行数,每100条显示一次,缓存区为500hbase(main)> count 't1', {INTERVAL => 100, CACHE => 500}