这里我们用一个学生成绩表作为例子,对HBase的基本操作和基本概念进行讲解:

下面是学生的成绩表:
name grad      course:math   course:art
Tom    1                87                    97

Jerry   2            100                  80

这里grad对于表来说是一个列,course对于表来说是一个列族,这个列族由两个列组成:math和art,当然我们可以根据我们的需要在course中建立更多的列族,如computer,physics等相应的列添加入course列族.

有了上面的想法和需求,我们就可以在HBase中建立相应的数据表啦!

1, 建立一个表格 scores 具有两个列族grad 和courese

hbase(main):002:0> create 'scores', 'grade', 'course'

0 row(s) in 4.1610 seconds

2,查看当先HBase中具有哪些表

hbase(main):003:0> list

scores

1 row(s) in 0.0210 seconds

3,查看表的构造

hbase(main):004:0> describe 'scores'

{NAME => 'scores', IS_ROOT => 'false', IS_META => 'false', FAMILIES => [{NAME => 'course', BLOOMFILTER => 'false', IN_MEMORY => 'false', LENGTH => '2147483647', BLOCKCACHE => 'false', VERSIONS => '3', TTL => '-1', COMPRESSION => 'NONE'}, {NAME => 'grade', BLOOMFILTER => 'false', IN_MEMORY => 'false', LENGTH => '2147483647', BLOCKCACHE => 'false', VERSIONS => '3', TTL => '-1', COMPRESSION => 'NONE'}]}

1 row(s) in 0.0130 seconds

4, 加入一行数据,行名称为 Tom 列族grad的列名为”” 值位1

hbase(main):005:0> put 'scores', 'Tom', 'grade:', '1'

0 row(s) in 0.0070 seconds

5,给Tom这一行的数据的列族添加一列

hbase(main):006:0> put 'scores', 'Tom', 'course:math', '87'

0 row(s) in 0.0040 seconds

6,给Tom这一行的数据的列族添加一列

hbase(main):007:0> put 'scores', 'Tom', 'course:art', '97'

0 row(s) in 0.0030 seconds

7, 加入一行数据,行名称为 Jerry 列族grad的列名为”” 值位2

hbase(main):008:0> put 'scores', 'Jerry', 'grade:', '2'

0 row(s) in 0.0040 seconds

8,给Jerry这一行的数据的列族添加一列

hbase(main):009:0> put 'scores', 'Jerry', 'course:math', '100'

0 row(s) in 0.0030 seconds

9,给Jerry这一行的数据的列族添加一列

hbase(main):010:0> put 'scores', 'Jerry', 'course:art', '80'

0 row(s) in 0.0050 seconds

10,查看scores表中Tom的相关数据

hbase(main):011:0> get 'scores', 'Tom'

COLUMN                       CELL

course:art                  timestamp=1224726394286, value=97

course:math                 timestamp=1224726377027, value=87

grade:                      timestamp=1224726360727, value=1

3 row(s) in 0.0070 seconds

11,查看scores表中所有数据

hbase(main):012:0> scan 'scores'

ROW                          COLUMN+CELL

Tom                         column=course:art, timestamp=1224726394286, value=97

Tom                         column=course:math, timestamp=1224726377027, value=87

Tom                         column=grade:, timestamp=1224726360727, value=1

Jerry                        column=course:art, timestamp=1224726424967, value=80

Jerry                        column=course:math, timestamp=1224726416145, value=100

Jerry                        column=grade:, timestamp=1224726404965, value=2

6 row(s) in 0.0410 seconds

12,查看scores表中所有数据courses列族的所有数据

hbase(main):013:0> scan 'scores', ['course:']

ROW                          COLUMN+CELL

Tom                         column=course:art, timestamp=1224726394286, value=97

Tom                         column=course:math, timestamp=1224726377027, value=87

Jerry                        column=course:art, timestamp=1224726424967, value=80

Jerry                        column=course:math, timestamp=1224726416145, value=100

4 row(s) in 0.0200 seconds

上面就是HBase的基本shell操作的一个例子,可以看出,hbase的shell还是比较简单易用的,从中也可以看出HBase shell缺少很多传统sql中的一些类似于like等相关操作,当然,HBase作为BigTable的一个开源实现,而BigTable是作为 google业务的支持模型,很多sql语句中的一些东西可能还真的不需要.

当然,通过 程序我们也可以对HBase进行相关的操作.下面的程序就完成了上面shell操作的内容:

import java.io.IOException;

import java.io.ByteArrayOutputStream;

import java.io.DataOutputStream;

import java.io.ByteArrayInputStream;

import java.io.DataInputStream;

import java.util.Map;

import org.apache.hadoop.io.Writable;

import org.apache.hadoop.io.IntWritable;

import org.apache.hadoop.hbase.HBaseConfiguration;

import org.apache.hadoop.hbase.HTableDescriptor;

import org.apache.hadoop.hbase.HColumnDescriptor;

import org.apache.hadoop.hbase.client.HBaseAdmin;

import org.apache.hadoop.hbase.client.HTable;

import org.apache.hadoop.hbase.io.BatchUpdate;

import org.apache.hadoop.hbase.io.RowResult;

import org.apache.hadoop.hbase.io.Cell;

import org.apache.hadoop.hbase.util.Writables;

public class HBaseBasic {

public static void main(String[] args) throws Exception {

HBaseConfiguration config = new HBaseConfiguration();

HBaseAdmin admin = new HBaseAdmin(config);

if (admin.tableExists("scores")) {

System.out.println("drop table");

admin.disableTable("scores");

admin.deleteTable("scores");

}

System.out.println("create table");

HTableDescriptor tableDescripter = new HTableDescriptor("scores".getBytes());

tableDescripter.addFamily(new HColumnDescriptor("grade:"));

tableDescripter.addFamily(new HColumnDescriptor("course:"));

admin.createTable(tableDescripter);

HTable table = new HTable(config, "scores");

System.out.println("add Tom's data");

BatchUpdate tomUpdate = new BatchUpdate("Tom");

tomUpdate.put("grade:", Writables.getBytes(new IntWritable(1)));

tomUpdate.put("course:math", Writables.getBytes(new IntWritable(87)));

tomUpdate.put("course:art", Writables.getBytes(new IntWritable(97)));

table.commit(tomUpdate);

System.out.println("add Jerry's data");

BatchUpdate jerryUpdate = new BatchUpdate("Jerry");

jerryUpdate.put("grade:", Writables.getBytes(new IntWritable(2)));

jerryUpdate.put("course:math", Writables.getBytes(new IntWritable(100)));

jerryUpdate.put("course:art", Writables.getBytes(new IntWritable(80)));

table.commit(jerryUpdate);

for (RowResult row : table.getScanner(new String[] { "course:" })) {

System.out.format("ROW\t%s\n", new String(row.getRow()));

for (Map.Entry<byte[], Cell> entry : row.entrySet()) {

String column = new String(entry.getKey());

Cell cell = entry.getValue();

IntWritable value = new IntWritable();

Writables.copyWritable(cell.getValue(), value);

System.out.format(" COLUMN\t%s\t%d\n", column, value.get());

}

}

}

}

输出如下:

drop table

09/07/11 08:51:59 INFO client.HBaseAdmin: Disabled scores

09/07/11 08:51:59 INFO client.HBaseAdmin: Deleted scores

create table

add Tom's data

add Jerry's data

ROW     Tom

COLUMN        course:art      97

COLUMN        course:math     87

ROW     Jerry

COLUMN        course:art      80

COLUMN        course:math     100

HBase简单代码实例(Java)相关推荐

  1. java练手代码大全手机版_java循环练习的简单代码实例

    ★打印九九乘法表 public class TestDemo { public static void main(String[] args){ for(int b=1;b<10;b++){ f ...

  2. JavaIO简单代码实例

    最近又复习了下JavaIO写了些实例代码都很简单但是能体现大部分方法的用法. IO流实现文件的拷贝   几种不同的方法: package com.wxisme.TestIO;import java.i ...

  3. Redis:安装、配置、操作和简单代码实例(C语言Client端)[转]

    我转的地址: http://blog.csdn.net/hj19870806/article/details/8724907 听说游戏的用的比较多,所以了解下. --以下为转载内容 Redis是一个开 ...

  4. java io 文件是否存在,代码实例Java IO判断目录和文件是否存在

    我们先来看完整的代码: import java.io.File; public class JudgeFile { public static void main(String[] args) { F ...

  5. Java建立Zip压缩文件的代码实例

    Java建立Zip压缩文件的代码实例 Java代码 import java.io.*; import java.util.zip.*; class Zip { public static void m ...

  6. TensorFlow个人学习(下载安装简单代码例子)

    (由于项目最终决定使用TensorFlow,所以博客来总结学习TensorFlow) 下载和安装: 由于TensorFlow也官方支持windows了,省去了很多功夫,安装就更简单了. TensorF ...

  7. ajax 示例代码,Ajax的简单实用实例代码

    我将实现一个简单的Ajax页面无刷新进行用户验证案例: 效果如下图: 实现主要过程: 在UsersAction类中的checkUser方法中接收并验证前台的表单数据,针对不同情况,返回一个状态码cod ...

  8. java调试案例_Spring-boot的debug调试代码实例

    这篇文章主要介绍了Spring-boot的debug调试代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 xml文件中配置: scf.serv ...

  9. php ajax简单实例代码,Ajax的简单实用实例代码

    这篇文章主要介绍了Ajax的简单实用实例代码,对ajax感兴趣的朋友可以参考下Ajax的简单实用的方法 我将实现一个简单的Ajax页面无刷新进行用户验证案例: 效果如下图: 实现主要过程: 在User ...

最新文章

  1. 装饰模式(Decorator Pattern)
  2. java基础----Runtime类的使用(一)
  3. 欢迎来到OpenGL的世界
  4. Spring 3.2的REST异常处理
  5. BZOJ3434 [Wc2014]时空穿梭
  6. 北京联合大学计算机学院在哪个校区,北京联合大学各校区联系地址大全
  7. Kubernetes 日志查询分析实践
  8. 博弈——Nim博弈(hdu2176,1850,1851,1907,1849)
  9. 学习c/c++的50个好网站(转)
  10. WlMAP:突破内网端口转发映射工具
  11. 设置谷歌浏览器黑色主题
  12. tier1和tier2_数据中心Tier1-Tier2-Tier3-Tier4
  13. 2019年末,10 位院士对 AI 的深度把脉(下)
  14. Keil uVision5开发一个基于LPC17XX系列芯片的工程文件
  15. html内嵌式选择器,CSS样式 CSS选择器(Cascading Style Sheet)
  16. 数据结构之——关键路径
  17. 深度学习:权重衰减(weight decay)与学习率衰减(learning rate decay)
  18. 辽宁省大连市谷歌高清卫星地图下载
  19. 《一斛珠·元夜月蚀》
  20. CRF进行实体的识别

热门文章

  1. 【Android 事件分发】ItemTouchHelper 事件分发源码分析 ( 绑定 RecyclerView )
  2. 【Android RTMP】x264 编码器初始化及设置 ( 获取 x264 编码参数 | 编码规格 | 码率 | 帧率 | B帧个数 | 关键帧间隔 | 关键帧解码数据 SPS PPS )
  3. 【Kotlin】Kotlin enum 枚举类 ( 常用用法 | 初始化成员变量 | 实现抽象方法 | 实现接口 | 获取名称和位置索引 | 调用枚举常量方法 )
  4. 大龄开发人员如何破局
  5. 《java语法实例2~15章》
  6. 对应用程序启动时所有方法的调用顺序分析
  7. 三层学习------实践篇
  8. 基于蚁群算法的岸桥作业顺序研究
  9. WCF扩展:行为扩展Behavior Extension一
  10. React入门看这篇就够了