使用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"); / ...
随机推荐
- Guava包学习--Multiset
Multiset之前倒是没用过,后来看了下还挺有用,其实它就是支持重复元素的HashSet,相当于list+set的集合,综合了两种集合的优点. 它扩展了Collection: @GwtCompati ...
- spring整合mongo及调用
spring整合mongo(maven工程下): 1.web.xml文件中配置需要加载的配置文件: <listener> <listener-class>org.springf ...
- python学习day25 正则表达式
4.30-25 正则表达式与re模块 re模块本身是用来操作正则表达式,与正则本身没有关系 正则表达式是指一规则,匹配字符串的规则 1.正则表达式regex 正则表达式regex是指一规则,匹配字符串 ...
- [转]PowerDesigner使用常见问题锦集
1. 附加:PowerDesigner 的调色板(Palette)快捷工具栏不见了,怎么重新打开,找回来呢 上网搜索了一下”powerdesigner 图形工具栏”,找到了找回PowerDesigne ...
- Reading Meticulous Measurement of Control Packets in SDN
SOSR 17 概要 网络流量中有一部分是用于网络管理,(根据packet process survey,该部分流量属于包转发的slow path部分)由于sdn的数控分离,交换机需要向控制器发送大量 ...
- 1<=portNo<=4竟然在keil4.71里面不报错
1.if( 1<=portNo<=4 ) { CardIn2_CS_L; //pull low CardIn1_CS_H; CardOut1_CS_H; CardOut2_CS_H ...
- JavaScript前端将时间戳转换为日期格式
function (data) { var date = new Date(data) var Y = date.getFullYear() + '-' var M = (date.getMonth( ...
- css让不同大小的图片适应div的大小,且不变形。
做成背景图片 单个 .imgdiv { width: 100px; // 你要的正方形 height: 100px; // 你要的正方形 background-image: url(/your/ima ...
- 一点一点看JDK源码(〇)
一点一点看JDK源码(〇) liuyuhang原创,未经允许进制转载 写在前面: 几乎所有的大神都会强调看源码,也强调源码的重要性: 但是如何看源码,源码看什么?看了什么用?看了怎么用? 困扰很多人, ...
- Win 10安装11g 客户端条件检查失败,INS-30131 无法从节点 "desktop-njm3a7m" 检索 exectask 的版本
Win 10安装11g 客户端条件检查失败,[INS-30131] 执行安装程序验证所需的初始设置失败.无法从节点 "desktop-njm3a7m" 检索 exectask 的版 ...