使用Java Api 对HBase进行简单操作
/** * 功能:测试Hbase基本的增删改查操作 * Created by liuhuichao on 2016/12/5. */ public class HbaseCRUDTest { public static Configuration configuration; static{ configuration= HBaseConfiguration.create(); configuration.set("hbase.zookeeper.quorum","lhc-centos"); } /** * 测试创建student表:测试已通过 * @throws IOException */ @Test public void createTable() throws IOException { HBaseAdmin admin=new HBaseAdmin(configuration); //HBaseAdmin负责管理HBase集群,添加和丢弃表 if(admin.tableExists("studentInfo")){ System.out.println("student表已经存在"); return; } HTableDescriptor descriptor=new HTableDescriptor("studentInfo"); descriptor.addFamily(new HColumnDescriptor("Name"));//创建列族,名字是Name descriptor.addFamily(new HColumnDescriptor("Address"));//创建列族,名字是Address admin.createTable(descriptor); //创建表 System.out.println("student表创建成功!!!"); } /** * 功能:想hbase中插入一行记录 --测试已通过 * @throws IOException */ @Test public void insertHbaseStudentTable() throws IOException { HTable table=new HTable(configuration, Bytes.toBytes("studentInfo")); Put put=new Put(Bytes.toBytes("1")); put.addColumn(Bytes.toBytes("Name"),Bytes.toBytes("firstName"),Bytes.toBytes("liu")); put.addColumn(Bytes.toBytes("Name"),Bytes.toBytes("secondName"),Bytes.toBytes("huichao")); put.addColumn(Bytes.toBytes("Address"),Bytes.toBytes("province"),Bytes.toBytes("hebei")); put.addColumn(Bytes.toBytes("Address"),Bytes.toBytes("city"),Bytes.toBytes("baoding")); put.addColumn(Bytes.toBytes("Address"),Bytes.toBytes("area"),Bytes.toBytes("qingyuan")); table.put(put); } /** * 功能:根据行健获取数据 * @throws IOException */ @Test public void getDataByRowKey() throws IOException { HTable table=new HTable(configuration, Bytes.toBytes("studentInfo")); Get get=new Get(Bytes.toBytes("1")); Result result=table.get(get); for(KeyValue kv :result.list()){ System.out.println("family:"+Bytes.toString(kv.getFamilyArray()));//所属列族名称 System.out.println("qualifier:"+Bytes.toString(kv.getQualifier()));//列名称 System.out.println("value:"+Bytes.toString(kv.getValue()));//存储的值 System.out.println("Timestamp:"+kv.getTimestamp());//获取时间戳 } } /** * 功能:测试全表扫描 * @throws IOException */ @Test public void selectHBaseScan() throws IOException { HTable table=new HTable(configuration, Bytes.toBytes("studentInfo")); /*遍历查询*/ Scan scan=new Scan(); ResultScanner rs=null; try { rs=table.getScanner(scan); for(Result result : rs){ for(KeyValue kv : result.list()){ System.out.println("family:"+Bytes.toString(kv.getFamilyArray()));//所属列族名称 System.out.println("qualifier:"+Bytes.toString(kv.getQualifier()));//列名称 System.out.println("value:"+Bytes.toString(kv.getValue()));//存储的值 System.out.println("Timestamp:"+kv.getTimestamp());//获取时间戳 } } }finally { rs.close(); } } /** * 更新 * @throws Exception */ @Test public void updateHBase() throws Exception{ HTable table=new HTable(configuration,Bytes.toBytes("studentInfo")); Put put=new Put(Bytes.toBytes("1")); //设置行健 put.add(Bytes.toBytes("Address"),Bytes.toBytes("city"),Bytes.toBytes("beijing"));///更新的时候找对族名和列名,再给定新的value值就可以了 table.put(put); } /** * 功能:查询nickname的多个(本示例为2个)版本值. * @throws Exception */ @Test public void selectSomeVersion() throws Exception{ HTable table=new HTable(configuration,Bytes.toBytes("studentInfo")); Get get=new Get(Bytes.toBytes("1")); get.addColumn(Bytes.toBytes("Address"),Bytes.toBytes("city")); // get.setMaxVersions(3); List<KeyValue> results=table.get(get).list(); int total=results.size(); System.out.println("Address列族中city列的各个版本值"); for(int i=0;i<total;i++){ System.out.println(Bytes.toString(results.get(i).getValue())); } } /** * 功能:删除指定的某一行 * @throws Exception */ @Test public void deleteColumn() throws Exception{ HTable table = new HTable(configuration, Bytes.toBytes("studentInfo"));//HTabel负责跟记录相关的操作如增删改查等 Delete deleteAll = new Delete(Bytes.toBytes("1")); table.delete(deleteAll); } /** * 功能:删除表 * @throws Exception */ @Test public void deleteTable() throws Exception{ HBaseAdmin admin=new HBaseAdmin(configuration); //HBaseAdmin负责管理HBase集群,添加和丢弃表 admin.disableTable("student"); admin.deleteTable("student"); } }
使用Java Api 对HBase进行简单操作的更多相关文章
- Hbase框架原理及相关的知识点理解、Hbase访问MapReduce、Hbase访问Java API、Hbase shell及Hbase性能优化总结
转自:http://blog.csdn.net/zhongwen7710/article/details/39577431 本blog的内容包含: 第一部分:Hbase框架原理理解 第二部分:Hbas ...
- 通过Java Api与HBase交互(转)
HBase提供了Java Api的访问接口,掌握这个就跟Java应用使用RDBMS时需要JDBC一样重要,本文将继续前两篇文章中blog表的示例,介绍常用的Api. import java.io.IO ...
- Java使用poi对Execl简单操作_总结
poi是Apache组织给开发者提供一套操作office(Execl,Word,PowerPoint)等Java API,开发者通过Poi API可以快速的操作office办公软件,以上3篇博文只是一 ...
- HBase总结(十二)Java API 与HBase交互实例
HBase提供了Java Api的訪问接口,掌握这个就跟Java应用使用RDBMS时须要JDBC一样重要 import java.io.IOException; import org.apache.h ...
- 通过Java Api与HBase交互
HBase提供了Java Api的访问接口,掌握这个就跟Java应用使用RDBMS时需要JDBC一样重要,本文将继续前两篇文章中blog表的示例,介绍常用的Api. import java.io.IO ...
- JAVA API访问Hbase org.apache.hadoop.hbase.client.RetriesExhaustedException: Failed after attempts=32
Java使用API访问Hbase报错: 我的hbase主节点是spark1 java代码访问hbase的时候写的是ip 结果运行程序报错 不能够识别主机名 修改主机名 修改主机hosts文 ...
- 使用JAVA API编程实现简易Habse操作
使用JAVA API编程实现下面内容: 1.创建<王者荣耀>游戏玩家信息表gamer,包含列族personalInfo(个人信息).recordInfo(战绩信息).assetsInfo( ...
- Java Api与HBase交互实例
import java.io.IOException; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hb ...
- Java中对session的简单操作
1.jsp中操作session <% String name=(String)request.getSession().getAttribute("username"); / ...
随机推荐
- CentOS7.X安装Redis-4.0.8以及Redis集群搭建
安装redis 安装前的准备 yum install \ vim \ wget \ make \ gcc \ gcc-c++ \ automake \ autoconf \ -y \ 下载解压并安装 ...
- JavaScript浏览器对象模型(BOM)之window对象
一.BOM概述 BOM(Browser Object Model)浏览器对象模型,它提供了很多对象,用于访问浏览器的功能. BOM 缺少规范,每个浏览器提供商又按照自己想法去扩展它,那么浏览器共有对象 ...
- hdu 1874 Dijkstra算法
先贴个网上找的比较通俗易懂的教程: 2.1Dijkstra算法(非负权,使用于有向图和无向图) Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心 ...
- C/C++——指针,引用做函数形参
函数中的形参是普通形参的时,函数只是操纵的实参的副本,而无法去修改实参. 引用形参是对实参的直接操纵,指针形参是对 它所指向的值(*p) 的直接操纵,但是对于这个指针变量(p)来说,依然只是副本. 指 ...
- ethereumjs/ethereumjs-block-1-简介
https://github.com/ethereumjs/ethereumjs-block Encoding, decoding and validation of Ethereum's Block ...
- vector详讲(三)实例
移动语义: push语句有时候会通过移动语义来提高性能 #include <iostream> #include <vector> class Element { public ...
- nginx下配置多个web服务
参考 nginx配置详解 nginx反向代理与负载均衡详解 一.nginx简介: Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能 ...
- PAT——1048. 数字加密
本题要求实现一种数字加密方法.首先固定一个加密用正整数A,对任一正整数B,将其每1位数字与A的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对13取余——这里用J代表10.Q代表11.K代 ...
- 两个事务 update同一张表出现的死锁问题 (转载)
引言 近来做省一级计算机一级考试系统的时候,学生端进行大批量判分的时候,出现了这样的问题(事务(进程 ID 262)与另一个进程被死锁在 锁 资源上,并且已被选作死锁牺牲品.请重新运行该事务.): 这 ...
- Android开发之自己定义TabHost文字及背景(源码分享)
使用TabHost 能够在一个屏幕间进行不同版面的切换,而系统自带的tabhost界面较为朴素,我们应该怎样进行自己定义改动优化呢 MainActivity的源码 package com.dream. ...