hbase  
访问habse三种方式 
访问hbase table中的行,只有三种方式: 
1 通过单个row key访问 
2 通过row key的range 
3 全表扫描 

 Row key行键 (Row key)可以是任意字符串(最大长度是 64KB,实际应用中长度一般为 10-100bytes),在hbase内部,row key保存为字节数组。 
Hbase会对表中的数据按照rowkey排序(字典顺序) 
hbase的时间戳 
时间戳的类型是 64位整型。时间戳可以由hbase(在数据写入时自动 )赋值,此时时间戳是精确到毫秒的当前系统时间。时间戳也可以由客户显式赋值。如果应用程序要避免数据版本冲突,就必须自己生成具有唯一性的时间戳。每个 cell中,不同版本的数据按照时间倒序排序,即最新的数据排在最前面。 
hbase shell命令 
进入hbase命令行 
./hbase shell 
显示hbase中的表 
list 
创建user表,包含info、data两个列族 
create 'user', 'info', 'data' 
 
put的用法(hbase添加数据)
例子1:

 向user表中插入信息,row key为rk0001,列族info中添加name列标示符,值为zhangsan 
put 'user', 'rk0001', 'info:name', 'zhangsan' 
例子2:
向user表中插入信息,row key为rk0001,列族info中添加gender列标示符,值为female 
put 'user', 'rk0001', 'info:gender', 'female' 
info:后面的name 和gender称为 列名 。 
get的用法(hbase中获取数据)
例子1
获取user表中row key为rk0001的所有信息 
get 'user', 'rk0001' 
例子2 
获取user表中row key为rk0001,info列族的所有信息 
get 'user', 'rk0001', 'info' 
例子3 
获取user表中row key为rk0001,info列族的name、age列标示符的信息 
get 'user', 'rk0001', 'info:name', 'info:age'

 

例子4 
获取user表中row key为rk0001,info、data列族的信息 
get 'user', 'rk0001', 'info', 'data' 
get 'user', 'rk0001', {COLUMN => ['info', 'data']} 
获取user表中row key为rk0001,info列族的name列标示符和data列族的pic列标示符信息 
get 'user', 'rk0001', {COLUMN => ['info:name', 'data:pic']} 
例子5 
获取user表中row key为rk0001,列族为info,版本号最新5个的信息 
get 'user', 'rk0001', {COLUMN => 'info', VERSIONS => 5} 
例子6 
查询的是表名为testByCrq,过滤方式是通过rowkey过滤,匹配出rowkey含111的数据。 
scan 'testByCrq', FILTER=>"RowFilter(=,'substring:111')" 
例子7 
获取user表中row key为rk0001,cell的值为zhangsan的信息 
get 'people', 'rk0001', {FILTER => "ValueFilter(=,'binary: zhangsan')"} 
例子8 
查询的是表名为testByCrq,过滤方式是通过rowkey过滤,匹配出rowkey小于等于0111486816556的数据。 
scan 'testByCrq', FILTER=>"RowFilter(<=,'binary:0111486816556')" 
例子9 
查询的是表名为testByCrq,过滤方式是通过value过滤,匹配出value含111的数据。 
scan 'testByCrq', FILTER=>"ValueFilter(=,'substring:111')" 
例子10 
查询的是表名为testByCrq,过滤方式是通过列簇过滤,匹配出列簇含f的数据。  
scan 'testByCrq', FILTER=>"FamilyFilter(=,'substring:f')" 
例子11 
查询的是表名为testByCrq,过滤方式是通过前缀过滤过滤的是行键,匹配出前缀为00000的数据。 
scan 'testByCrq', FILTER=>"PrefixFilter('00000')" 
scan的用法(扫描数据)
例子1 
scan 'user' 
查询user表中的所有信息 
例子2 
查询user表中列族为info的信息 
scan 'user', {COLUMNS => 'info'} 
例子3 
查询user表中列族为info、列标示符为name的信息,并且版本最新的5个 
scan 'user', {COLUMNS => 'info:name', VERSIONS => 5} 
例子4 
查询user表中列族为info和data且列标示符中含有a字符的信息 
scan 'user', {COLUMNS => ['info', 'data'], FILTER => "(QualifierFilter(=,'substring:a'))"} 
例子5 
查询user表中列族为info,rk范围是[rk0001, rk0003)的数据 
scan 'people', {COLUMNS => 'info', STARTROW => 'rk0001', ENDROW => 'rk0003'} 
例子6 
查询user表中row key以rk字符开头的 
scan 'user',{FILTER=>"PrefixFilter('rk')"} 
例子7
 
查询user表的  列族为INFO的前20条
scan 'user',{COLUMNS=>'info',LIMIT=>20} 
delete的用法(删除数据) 
删除user表row key为rk0001,列标示符为info:name的数据 
delete 'people', 'rk0001', 'info:name' 
删除user表row key为rk0001,列标示符为info:name,timestamp为1392383705316的数据 
delete 'user', 'rk0001', 'info:name', 1392383705316
sniffer:person_tag_warehouse
scan 'sniffer:person_tag_warehouse', {COLUMNS => 'info'}