HBase的JavaAPI操作

简介:

如果是DDL的操作就找HbaseAdmin.

如果是表上的增删改查的操作就找HTable.

附录代码:

复制代码
  1 mport java.util.Arrays;
  2 
  3 import org.apache.hadoop.conf.Configuration;
  4 import org.apache.hadoop.hbase.HBaseConfiguration;
  5 import org.apache.hadoop.hbase.HColumnDescriptor;
  6 import org.apache.hadoop.hbase.HTableDescriptor;
  7 import org.apache.hadoop.hbase.KeyValue;
  8 import org.apache.hadoop.hbase.TableName;
  9 import org.apache.hadoop.hbase.client.Delete;
 10 import org.apache.hadoop.hbase.client.Get;
 11 import org.apache.hadoop.hbase.client.HBaseAdmin;
 12 import org.apache.hadoop.hbase.client.HTable;
 13 import org.apache.hadoop.hbase.client.Put;
 14 import org.apache.hadoop.hbase.client.Result;
 15 import org.apache.hadoop.hbase.client.ResultScanner;
 16 import org.apache.hadoop.hbase.client.Scan;
 17 import org.apache.hadoop.hbase.filter.CompareFilter.CompareOp;
 18 import org.apache.hadoop.hbase.filter.Filter;
 19 import org.apache.hadoop.hbase.filter.SingleColumnValueFilter;
 20 import org.junit.After;
 21 import org.junit.Before;
 22 import org.junit.Test;
 23 
 24 public class HBaseCRUDTest {
 25     
 26     private HBaseAdmin hBaseAdmin;
 27     private Configuration conf;
 28     
 29     /**
 30      * 对必须用的对象放在@Before中进行初始化
 31      * @throws Exception
 32      */
 33     @Before
 34     public void setUp() throws Exception{
 35         /*创建conf对象的第一种方式
 36         conf = new Configuration();
 37         conf.set("hbase.rootdir", "hdfs://crxy99:9000/hbase");
 38         conf.set("hbase.cluster.distributed", "true");
 39         conf.set("hbase.zookeeper.quorum", "crxy99");
 40         */
 41         //创建对象的第二种方式
 42         //这种方式需要再Maven的src/test/resoures目录中放置Hbase集群上的hbase-site.xml文件.
 43         conf = HBaseConfiguration.create();
 44         
 45         hBaseAdmin = new HBaseAdmin(conf);//通过Configuration对象得到HBaseAdmin对象.
 46         System.out.println("-------setUp-------");
 47         
 48     }
 49     
 50     
 51     /**
 52      * 是用完HBaseAdmin对象之后需要关闭.
 53      * @throws Exception
 54      */
 55     @After
 56     public void cleanUp() throws Exception {
 57         hBaseAdmin.close();
 58         System.out.println("-------cleanUp-----");
 59     }
 60     
 61     
 62     /**
 63      * 打印出Hbase中所有的表.
 64      * @throws Exception
 65      */
 66     @Test
 67     @SuppressWarnings("deprecation")
 68     public void testListTables() throws Exception{
 69         System.out.println("------listTables------");
 70         //获得Hbase中表的方法一:
 71         String [] tableNames = hBaseAdmin.getTableNames();
 72         System.out.println(Arrays.toString(tableNames));
 73         
 74         //获得Hbase中表的方法二:
 75         TableName[] listTables= hBaseAdmin.listTableNames();
 76         System.out.println(Arrays.toString(listTables));
 77         
 78         //获得Hbase中表的方法三(用到了HTableDescriptor对象):
 79         HTableDescriptor[] listTabels2 = hBaseAdmin.listTables();
 80         for (HTableDescriptor hTD : listTabels2) {
 81             System.out.print(hTD.getTableName() + " ");
 82         }
 83         System.out.println();
 84     }
 85     
 86     /**
 87      * 向HBase中增加一个表
 88      */
 89     @Test
 90     public void testAddTable() throws Exception {
 91         System.out.println("-----addTable-----");
 92         HTableDescriptor desc = new HTableDescriptor("t2");//创建表的名称
 93         HColumnDescriptor family = new HColumnDescriptor("cf"); //创建表的列族
 94         desc.addFamily(family);//向表中添加列族 (Hbase在创建表的时候就要添加列族.)
 95         /*
 96          *HBase对单行做到了一个事务,hbase不支持跨行的事务 
 97          */
 98         
 99         //table.checkAndPut(row, family, qualifier, value, put)
100         
101         hBaseAdmin.createTable(desc);
102     }
103     
104     /**
105      * 向表中插入数据
106      * 操作表中的数据就是需要操作表本身,需要用到了HTable对象.
107      */
108     @Test
109     public void testAddRecord() throws Exception {
110         HTable table = new HTable(conf, "t2");//操作上面新建的t2
111         String rowKey = "1";
112         String family = "cf";
113         //String qualifier = "name";
114         String qualifier = "age";
115         //String value = "SummerChill";
116         String value = "18";
117         Put put = new Put(rowKey.getBytes());//put对象传入的是一个"行键rowkey"
118         //HBase中存储的都是字节数组  
119         //插入表中数据的时候hbase的shell操作用的put命令,JavaAPI对应的是Put对象.
120         put.add(family.getBytes(), qualifier.getBytes(), value.getBytes());
121         table.put(put);
122         table.close();
123         System.out.println("------addRecord-------");
124     }
125     
126     /**
127      * 查询表中的数据
128      */
129     @SuppressWarnings("deprecation")
130     @Test
131     public void testQueryRecord() throws Exception {
132         HTable table = new HTable(conf, "t2");
133         String rowKey = "1";
134         //查询表中数据的时候HBase的shell操作用的get命令,JavaAPI对应的是Get对象.
135         Get get = new Get(rowKey.getBytes());
136         get.addColumn("cf".getBytes(), "age".getBytes());
137         Result result = table.get(get);
138         KeyValue[] keyVs =  result.raw();
139         for(KeyValue kv : keyVs ){
140             byte[] qualifier = kv.getQualifier();
141             byte[] value = kv.getValue();
142             System.out.println(new String(qualifier) + "=" + new String(value));
143         }
144         table.close();
145         System.out.println("-----getRecord-----");
146     }
147     
148     /**
149      * 条件查询 
150      */
151     @SuppressWarnings("deprecation")
152     @Test
153     public void testQueryByCondition() throws Exception {
154         HTable table = new HTable(conf, "t2");
155         Scan scan = new Scan();
156         Filter filter = new SingleColumnValueFilter(
157                 "cf".getBytes(),"age".getBytes(),
158                 CompareOp.GREATER, "13".getBytes());
159         //CompareOp是一个操作的枚举常量
160         scan.setFilter(filter);
161         ResultScanner rs = table.getScanner(scan);
162         
163         for (Result result : rs) {
164             KeyValue[] keyVs = result.raw();
165             for (KeyValue kv : keyVs) {
166                 byte[] qualifier = kv.getQualifier();
167                 byte[] value = kv.getValue();
168                 System.out.print(new String(qualifier) + "=" + new String(value) + " ");
169             }
170             System.out.println();
171         }
172         table.close();
173         System.out.println("-----getRecord-----");
174     }
175     
176     /**
177      * 删除表中的记录
178      */
179     @Test
180     public void testDeleteRecored() throws Exception {
181         HTable table = new HTable(conf, "t2");
182         byte[] row = "2".getBytes();
183         Delete delete = new Delete(row);
184         //删除指定的rowkey对应的某一列
185         //delete.deleteColumn("cf".getBytes(), "age".getBytes());
186         table.delete(delete);
187         table.close();
188         System.out.println("-----deleteRecord-----");
189     }
190     
191     /**
192      * 删除表
193      */
194     @Test
195     public void testDropTable() throws Exception {
196         //删除表之前对表是否存在进行判断.
197         if(!hBaseAdmin.tableExists("t2")) {
198             throw new RuntimeException("Table Not Exists,你想弄啥嘞!");
199         }
200         if(hBaseAdmin.isTableEnabled("t2")) {
201             hBaseAdmin.disableTable("t2");
202         }
203         //在删除表之前必须对表设置disable,否则直接删除 会抛出异常
204         hBaseAdmin.deleteTable("t2");
205         System.out.println("-----deleteTable-----");
206     }
207 
208 }
复制代码

 


本文转自SummerChill博客园博客,原文链接:http://www.cnblogs.com/DreamDrive/p/5572060.html,如需转载请自行联系原作者

相关实践学习
lindorm多模间数据无缝流转
展现了Lindorm多模融合能力——用kafka API写入,无缝流转在各引擎内进行数据存储和计算的实验。
云数据库HBase版使用教程
  相关的阿里云产品:云数据库 HBase 版 面向大数据领域的一站式NoSQL服务,100%兼容开源HBase并深度扩展,支持海量数据下的实时存储、高并发吞吐、轻SQL分析、全文检索、时序时空查询等能力,是风控、推荐、广告、物联网、车联网、Feeds流、数据大屏等场景首选数据库,是为淘宝、支付宝、菜鸟等众多阿里核心业务提供关键支撑的数据库。 了解产品详情: https://cn.aliyun.com/product/hbase   ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
8月前
|
分布式计算 资源调度 Hadoop
HBase表数据的读、写操作与综合操作
HBase表数据的读、写操作与综合操作
104 0
|
存储 分布式计算 Hadoop
Hbase JavaAPI使用 2
Hbase JavaAPI使用
121 0
|
8月前
|
Java Shell 分布式数据库
【大数据技术Hadoop+Spark】HBase数据模型、Shell操作、Java API示例程序讲解(附源码 超详细)
【大数据技术Hadoop+Spark】HBase数据模型、Shell操作、Java API示例程序讲解(附源码 超详细)
168 0
|
Shell 分布式数据库 Apache
Hbase常用shell操作
Hbase常用shell操作
444 1
|
Java Shell 分布式数据库
HBase高级操作
HBase高级操作
309 0
|
SQL 大数据 Shell
大数据HBase JavaAPI工具类
大数据HBase JavaAPI工具类
160 0
|
8月前
|
分布式计算 Hadoop Shell
熟悉常用的HBase操作
熟悉常用的HBase操作
180 3
熟悉常用的HBase操作
|
3月前
|
SQL 分布式计算 Hadoop
Hadoop-37 HBase集群 JavaAPI 操作3台云服务器 POM 实现增删改查调用操作 列族信息 扫描全表
Hadoop-37 HBase集群 JavaAPI 操作3台云服务器 POM 实现增删改查调用操作 列族信息 扫描全表
45 3
|
8月前
|
分布式计算 Hadoop Shell
|
6月前
|
DataWorks 数据管理 大数据
DataWorks操作报错合集之在连接HBase时出现超时问题,该怎么解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。