Hbase——API操作
1.判断表是否存在
public static boolean isTableExit(String tableName) throws IOException {
// //获取配置文件信息
// //HBaseConfiguration configuration=new HBaseConfiguration();
// Configuration configuration=HBaseConfiguration.create();
// configuration.set("hbase.zookeeper.quorum","master,s1,s2");
//
// //获取管理员对象
// //HBaseAdmin admin=new HBaseAdmin(configuration);
// Connection connection=ConnectionFactory.createConnection(configuration);
// Admin admin=connection.getAdmin();
//判断表是否存在
boolean exists=admin.tableExists(TableName.valueOf(tableName));
//关闭连接
// admin.close();
//返回结果
return exists;
}
2.创建表
public static void createTable(String tableName,String... cfs) throws IOException {
// 判断是否存在列族信息
if(cfs.length<=0){
System.out.println("请设置列族信息");
return;
}
//判断表是否存在
if(isTableExit(tableName)){
System.out.println(tableName+"表已存在");
return;
}
//创建表描述器
HTableDescriptor hTableDescriptor=new HTableDescriptor(TableName.valueOf(tableName));
//循环添加列族信息
for(String cf:cfs){
//创建列祖描述器
HColumnDescriptor hColumnDescriptor=new HColumnDescriptor(cf);
// 添加具体列族信息
hTableDescriptor.addFamily(hColumnDescriptor);
}
//创建表
admin.createTable(hTableDescriptor);
}
3.删除表
public static void dropTable(String tableName) throws IOException {
//判断表是否存在
if (!isTableExit(tableName)){
System.out.println(tableName+"表不存在!");
return;
}
//先使表下线
admin.disableTable(TableName.valueOf(tableName));
// 删除表
admin.deleteTable(TableName.valueOf(tableName));
}
4.创建命名空间
public static void createNameSpace(String ns){
//创建命名空间描述器
NamespaceDescriptor namespaceDescriptor=NamespaceDescriptor.create(ns).build();
//创建命名空间
try {
admin.createNamespace(namespaceDescriptor);
} catch (NamespaceExistException e){
System.out.println(ns+"命名空间已存在");
}
catch (IOException e) {
e.printStackTrace();
}
}
完整代码:
package test; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.*;
import org.apache.hadoop.hbase.client.Admin;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.HBaseAdmin; import java.io.IOException; /*
DDL:
1.判断表是否存在
2.创建表
3.删除表 DML:
5.插入数据
6.查数据(get,scan)
7.删除数据
*/
public class TestAPI { private static Connection connection=null;
private static Admin admin=null; static { try { //获取配置信息
Configuration configuration=HBaseConfiguration.create();
configuration.set("hbase.zookeeper.quorum","master,s1,s2"); //创建连接对象
connection=ConnectionFactory.createConnection(configuration); //创建admin对象
admin=connection.getAdmin();
} catch (IOException e) {
e.printStackTrace();
}
}
//1.判断表是否存在
public static boolean isTableExit(String tableName) throws IOException {
// //获取配置文件信息
// //HBaseConfiguration configuration=new HBaseConfiguration();
// Configuration configuration=HBaseConfiguration.create();
// configuration.set("hbase.zookeeper.quorum","master,s1,s2");
//
// //获取管理员对象
// //HBaseAdmin admin=new HBaseAdmin(configuration);
// Connection connection=ConnectionFactory.createConnection(configuration);
// Admin admin=connection.getAdmin(); //判断表是否存在
boolean exists=admin.tableExists(TableName.valueOf(tableName)); //关闭连接
// admin.close(); //返回结果
return exists;
} //2.创建表
public static void createTable(String tableName,String... cfs) throws IOException { // 判断是否存在列族信息
if(cfs.length<=0){
System.out.println("请设置列族信息");
return;
} //判断表是否存在
if(isTableExit(tableName)){
System.out.println(tableName+"表已存在");
return;
} //创建表描述器
HTableDescriptor hTableDescriptor=new HTableDescriptor(TableName.valueOf(tableName)); //循环添加列族信息
for(String cf:cfs){ //创建列祖描述器
HColumnDescriptor hColumnDescriptor=new HColumnDescriptor(cf); // 添加具体列族信息
hTableDescriptor.addFamily(hColumnDescriptor);
} //创建表
admin.createTable(hTableDescriptor);
}
public static void close(){
if (admin!=null){
try {
admin.close();
} catch (IOException e) {
e.printStackTrace();
}
} if(connection!=null){
try {
connection.close();
} catch (IOException e) {
e.printStackTrace();
}
} } //3.删除表
public static void dropTable(String tableName) throws IOException { //判断表是否存在
if (!isTableExit(tableName)){
System.out.println(tableName+"表不存在!");
return;
} //先使表下线
admin.disableTable(TableName.valueOf(tableName)); // 删除表
admin.deleteTable(TableName.valueOf(tableName));
} //4.创建命名空间
public static void createNameSpace(String ns){
//创建命名空间描述器
NamespaceDescriptor namespaceDescriptor=NamespaceDescriptor.create(ns).build(); //创建命名空间
try {
admin.createNamespace(namespaceDescriptor);
} catch (NamespaceExistException e){
System.out.println(ns+"命名空间已存在");
}
catch (IOException e) {
e.printStackTrace();
} }
public static void main(String[] args) throws IOException { //1.测试表是否存在
// System.out.println(isTableExit("stu5"));
//
// //2.创建表测试
createTable("0919:stu5","info1","info2");
//
// //检测表创建是否成功
// System.out.println(isTableExit("stu5"));
//
// //3.删除表测试
// dropTable("stu5");
//
// //检测表删除是否成功
// System.out.println(isTableExit("stu5")); //4.创建命名空间
createNameSpace("0919");
//关闭资源
close();
}
}
Hbase——API操作的更多相关文章
- HBase API操作
|的ascII最大ctrl+shift+t查找类 ctrl+p显示提示 HBase API操作 依赖的jar包 <dependencies> <dependency> < ...
- 5.Hbase API 操作开发
Hbase API 操作开发需要连接Zookeeper进行节点的管理控制 1.配置 HBaseConfiguration: 包:org.apache.hadoop.hbase.HBaseConfigu ...
- HBASE API操作问题总结
org.apache.hadoop.hbase.MasterNotRunningException 在centos中查看,发现没有HMaster进程 解决方法: 1.启动hadoop后,需要等一段时间 ...
- Hbase Shell命令详解+API操作
HBase Shell 操作 3.1 基本操作1.进入 HBase 客户端命令行,在hbase-2.1.3目录下 bin/hbase shell 2.查看帮助命令 hbase(main):001:0& ...
- 大数据技术之_11_HBase学习_02_HBase API 操作 + HBase 与 Hive 集成 + HBase 优化
第6章 HBase API 操作6.1 环境准备6.2 HBase API6.2.1 判断表是否存在6.2.2 抽取获取 Configuration.Connection.Admin 对象的方法以及关 ...
- HBase 6、用Phoenix Java api操作HBase
开发环境准备:eclipse3.5.jdk1.7.window8.hadoop2.2.0.hbase0.98.0.2.phoenix4.3.0 1.从集群拷贝以下文件:core-site.xml.hb ...
- HBase API 基础操作
对于数据操作,HBase支持四类主要的数据操作,分别是: Put :增加一行,修改一行 Delete :删除一行,删除指定列族,删除指定column的多个版本,删除指定column的制定版本等 Get ...
- 使用IDEA操作Hbase API 报错:org.apache.hadoop.hbase.client.RetriesExhaustedException的解决方法:
使用IDEA操作Hbase API 报错:org.apache.hadoop.hbase.client.RetriesExhaustedException的解决方法: 1.错误详情: Excepti ...
- Java API 操作HBase Shell
HBase Shell API 操作 创建工程 本实验的环境实在ubuntu18.04下完成,首先在改虚拟机中安装开发工具eclipse. 然后创建Java项目名字叫hbase-test 配置运行环境 ...
随机推荐
- 二、cadence焊盘与封装制作操作步骤详细说明
一.焊盘制作 1.打开Pad Designer软件,新建文件--设置保存路径和焊盘名称(规范命名) 2.Parameters--设置单位--过孔类型--是否镀金 3.Layers--single la ...
- 解决Mui中popover 顶部弹出菜单弹出位置不准确以及无法收回的问题
前言 最近公司的项目转向使用Hbuilder开发移动端项目,其中想要通过在顶部标题栏加入弹出菜单的方式,来定位长列表的位置,如图所示. 问题 Mui的功能貌似还不是很完善,在使用这个弹出菜单的时候,发 ...
- MySQL 中 SQL语句大全(详细)
sql语句总结 总结内容 1. 基本概念 2. SQL列的常用类型 3. DDL简单操作 3.1 数据库操作 3.2 表操作 4. DML操作 4.1 修改操作(UPDATE SET) 4.2 插入操 ...
- 解决vue安装时出现vue --version或vue不是内部命令的问题
1. 试图全局配置 vue 的环境变量,找到 vue.cmd 的路径,然后进行配置. 问题:在文件搜索中,没有找到 vue.cmd,失败. 1.npm i npm -g 全局 update 了 npm ...
- mongodb安装错误以及原理
安装mongodb,默认是安装到"C:\Program Files\MongoDB\"这里的,我在注册表里没有找到mongodb的信息,所以猜测它只是将其解压到那个位置而已,它只是 ...
- 利用css3实现3D轮播图
动画实现主要利用了z-index将层级关系改变,从而实现了焦点图的效果:css3属性 transform rotate 来实现图片的动画效果 .transition实现过度动画! * { margin ...
- 算法题——Cantor表
题目介绍 描述 现代数学的著名证明之一是 Georg Cantor 证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1, 1/2 , 1/3, 1/4, 1/5, - 2/1, 2/ ...
- 硬核 | Redis 布隆(Bloom Filter)过滤器原理与实战
在Redis 缓存击穿(失效).缓存穿透.缓存雪崩怎么解决?中我们说到可以使用布隆过滤器避免「缓存穿透」. 码哥,布隆过滤器还能在哪些场景使用呀? 比如我们使用「码哥跳动」开发的「明日头条」APP 看 ...
- for .. range中的坑
最近在开发中使用了for range来遍历一个slice,结果在测试的时候遇到了bug,最后定位是错误使用for range造成的,这里记录一下: func redisSlaveScanBigKeys ...
- 20202127 实验一《Python程序设计》实验报告
20202127 2022-2022-2 <Python程序设计>实验一报告课程:<Python程序设计>班级: 2021姓名: 马艺洲学号:20202127实验教师:王志强实 ...