熟悉常用的HBase操作

实验3

熟悉常用的HBase操作

 

 

1.实验目的

1理解HBaseHadoop体系结构中的角色;

2熟练使用HBase操作常用的Shell命令;

3熟悉HBase操作常用的Java API

2.实验平台

1操作系统:Linux(建议Ubuntu16.04Ubuntu18.04);

2Hadoop版本:3.1.3

3HBase版本:2.2.2

4JDK版本:1.8

5Java IDEEclipse

3. 实验步骤

(一)编程实现以下指定功能,并用Hadoop提供的HBase Shell命令完成相同任务:

(1) 列出HBase所有的表的相关信息,例如表名;

 

HBase Shell命令show tables;

  

Java API实现:

Admin admin = connection.getAdmin();  

TableName[] tableNames = admin.listTableNames();  

for (TableName tableName : tableNames) {  

     System.out.println(tableName.getNameAsString());  

}  

(2) 在终端打印出指定的表的所有记录数据;

HBase Shell命令

  

 

Java API实现:

 

Table table = connection.getTable(TableName.valueOf("test"));  

ResultScanner scanner = table.getScanner(new Scan());  

for (Result result : scanner) {  

      System.out.println(result);  

}

 

(3) 向已经创建好的表添加和删除指定的列族或列;

添加列族

HBase Shell命令alter 'test', {NAME => age'}

  

Java API实现:

HColumnDescriptor columnDescriptor = new HColumnDescriptor("newColumnFamily");  

admin.addColumn("'test", columnDescriptor);  

 

 

删除列

 

HBase Shell命令alter ''test', {NAME => 'columnFamily:column', METHOD => 'delete'}

 

 

 

  

Java API实现:

admin.deleteColumn("'test", "columnFamily:column");

 

 

 

 

 

(4) 清空指定的表的所有记录数据;

 

HBase Shell命令TRUNCATE  TABLE  test;

  

 

Java API实现:

admin.disableTable("'test");  

admin.deleteTable("'test");

 

(5) 统计表的行数。

 

 

HBase Shell命令SELECT COUNT(*) AS row_count FROM test;

  

 

 

Java API实现:

Scan scan = new Scan();  

ResultScanner scanner = table.getScanner(scan);  

int rowCount = 0;  

for (Result result : scanner) {  

     rowCount++;  

}  

System.out.println("Row count: " + rowCount);  

 

 

(二)HBase数据库操作

1. 现有以下关系型数据库中的表和数据(见表14-3到表14-5,要求将其转换为适合于HBase存储的表并插入数据:

14-3 学生表(Student

学号(S_No

姓名(S_Name

性别(S_Sex

年龄(S_Age

2015001

Zhangsan

male

23

2015002

Mary

female

22

2015003

Lisi

male

24

 

14-4 课程表(Course

课程号(C_No

课程名(C_Name

学分(C_Credit

123001

Math

2.0

123002

Computer Science

5.0

123003

English

3.0

 

14-5 选课表(SC

学号(SC_Sno

课程号(SC_Cno

成绩(SC_Score

2015001

123001

86

2015001

123003

69

2015002

123002

77

2015002

123003

99

2015003

123001

98

2015003

123002

95

 

2. 请编程实现以下功能:

1createTable(String tableName, String[] fields)

创建表,参数tableName为表的名称,字符串数组fields为存储记录各个字段名称的数组。要求当HBase已经存在名为tableName的表的时候,先删除原有的表,然后再创建新的表。

 

public void createTable(String tableName, String[] fields) throws IOException {  

    if (admin.tableExists(TableName.valueOf(tableName))) {  

        admin.disableTable(TableName.valueOf(tableName));  

        admin.deleteTable(TableName.valueOf(tableName));  

    }  

    HTableDescriptor tableDescriptor = new HTableDescriptor(TableName.valueOf(tableName));  

    for (String field : fields) {  

        tableDescriptor.addFamily(new HColumnDescriptor(field));  

    }  

    admin.createTable(tableDescriptor);  

}

 

2addRecord(String tableName, String row, String[] fields, String[] values)

向表tableName、行row(用S_Name表示)和字符串数组fields指定的单元格中添加对应的数据values。其中,fields中每个元素如果对应的列族下还有相应的列限定符的话,用“columnFamily:column”表示。例如,同时向“Math”“Computer Science”“English”三列添加成绩时,字符串数组fields{“Score:Math”, ”Score:Computer Science”, ”Score:English”},数组values存储这三门课的成绩。

 

public void addRecord(String tableName, String row, String[] fields, String[] values) throws IOException {  

    Table table = connection.getTable(TableName.valueOf(tableName));  

    Put put = new Put(Bytes.toBytes(row));  

    for (int i = 0; i < fields.length; i++) {  

        put.addColumn(Bytes.toBytes(fields[i].split(":")[0]), Bytes.toBytes(fields[i].split(":")[1]), Bytes.toBytes(values[i]));  

    }  

    table.put(put);  

}

 

3scanColumn(String tableName, String column)

浏览表tableName某一列的数据,如果某一行记录中该列数据不存在,则返回null。要求当参数column为某一列族名称时,如果底下有若干个列限定符,则要列出每个列限定符代表的列的数据;当参数column为某一列具体名称(例如“Score:Math”)时,只需要列出该列的数据。

 

public void scanColumn(String tableName, String column) throws IOException {  

    Table table = connection.getTable(TableName.valueOf(tableName));  

    Scan scan = new Scan();  

    if (column.contains(":")) {  

        scan.addColumn(Bytes.toBytes(column.split(":")[0]), Bytes.toBytes(column.split(":")[1]));  

    } else {  

        scan.addFamily(Bytes.toBytes(column));  

    }  

    ResultScanner scanner = table.getScanner(scan);  

    for (Result result : scanner) {  

        System.out.println(result);  

    }  

}

 

4modifyData(String tableName, String row, String column)

修改表tableName,行row(可以用学生姓名S_Name表示),列column指定的单元格的数据。

 

public void modifyData(String tableName, String row, String column, String newValue) throws IOException {  

    Table table = connection.getTable(TableName.valueOf(tableName));  

    Put put = new Put(Bytes.toBytes(row));  

    put.addColumn(Bytes.toBytes(column.split(":")[0]), Bytes.toBytes(column.split(":")[1]), Bytes.toBytes(newValue));  

    table.put(put);  

}

 

5deleteRow(String tableName, String row)

删除表tableNamerow指定的行的记录。

 

public void deleteRow(String tableName, String row) throws IOException {  

    Table table = connection.getTable(TableName.valueOf(tableName));  

    Delete delete = new Delete(Bytes.toBytes(row));  

    table.delete(delete);  

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/861603.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

风继续吹

风继续吹 一、学期回顾 1.1 回顾你对于软件工程课程的想象 在学期初,我对软件工程课程没多少了解,觉得它应该和之前的部分课程一样,老师讲解一些编程语法然后布置作业,后期周末去实验室编程完成实验,期末再复习一下这门课编写代码作答题目这门课也就过去了。但实际上的软工…

初识Spring -2024/12/30

Spring优点Spring FrameworkCore Container:核心容器 AOP:面向切面编程 Aspects: AOP思想实现 Data Access :数据访问 Data Integration: 数据集成IoC,IoC容器,Bean,DI导入依赖 <dependency><groupId>org.springframework</groupId><artifactId>spring…

【Leetcode】链表

链表 160. 相交链表 206. 反转链表 234. 回文链表 141. 环形链表 142. 环形链表 II 21. 合并两个有序链表 2. 两数相加 19. 删除链表的倒数第 N 个结点 25. K 个一组翻转链表 138. 随机链表的复制 148. 排序链表 23. 合并 K 个升序链表 146. LRU 缓存 160. 相交链表 方法一:模…

The end-软工实践之旅

一、学期回顾 1.1 回顾你对于软件工程课程的想象 在学期初,我眼中的软件工程课程是一门教大家如何从零开始开发软件,实际上大部分知识都需要自己学习掌握,软工课着重系统地学习软件开发流程,掌握从需求分析、设计、编码到测试的全套本领,雕琢出实用且受欢迎的软件作品。 如…

‍禁止蕉绿——软件工程个人总结

这个作业属于哪个课程 软件工程这个作业要求在哪里 软件工程2024秋——个人总结作业这个作业的目标 学期总结学号 102202150🙅‍禁止焦虑——2024秋软工实践个人总结博客 一、🎞️学期回顾🎞️ 1.1 💭回顾你对于软件工程课程的想象💭 刚开始我对软件工程的理解只局限…

《计算机组成及汇编语言原理》阅读笔记:p133-p159

《计算机组成及汇编语言原理》学习第 11 天,p133-p159 总结,总计 27 页。 一、技术总结 1.segment (1)定义 Broadly speaking, a contiguous section of memory. More specifically, a section of memory referenced by one of the segment registers of the 80x86 family.…

并非银河战舰,皮划艇也能启航

目录标题一、学期回顾1.1 回顾对软工课程的想象1.2 回顾在这门课程中的投入与产出1.3 最印象深刻的答辩二、总结收获2.1 自己的人月神话2.2 学习到的新技术和生产力工具2.3 除了技术之外,还得到了哪些提升2.4 对下一届实践的建议三、致谢这个作业属于哪个课程 https://edu.cnb…

GitHub Copilot免费上线!快速上手指南与功能解析

GitHub Copilot在12月宣布免费订阅,不再限制学生和开源项目的维护者了,对于习惯白嫖的开发者来说无疑多了一个选择。 价格和功能 免费版目前可以选择Claude 3.5 Sonnet或GPT-4o模型,每月可以调用 2000 次生成和补全代码,以及 50 次聊天信息。快速开始注册一个GIthub账号 VS…

C#/.NET/.NET Core技术前沿周刊 | 第 19 期(2024年12.23-12.29)

前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录、追踪C#/.NET/.NET Core领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿,助力技术成长与视野拓宽。欢迎投稿、推荐或自荐优质文章、项目、学习资源等…

Notepad – – (文本编辑器) v3.0.0 官方版

这是一个使用C++编写的文本编辑器Notepad- -,可以支持Win/Linux/Mac平台。 我们的目标是要替换Notepad++,重点在国产Uos系统、Mac 系统上发展。 一个支持windows/linux/mac的文本编辑器,目标是要替换notepad++,来自中国。 对比Notepad++而言,我们的优势是可以跨平台,支持l…

【Node.js编程】实现GETPOST请求

创建基本的服务器 const express = require(express); const indexRouter = require(./router); // 引入路由 const app = express(); const port = 3000; // 挂载路由 app.use(/api, indexRouter); app.listen(port, () => {console.log(`Server is running on http://loca…

openEuler RISC-V上磁盘I/O性能测试的IOZone实例

IOZone 是一个广泛使用的文件系统性能基准测试工具,旨在评估磁盘 I/O 性能。它能够测试各种类型的文件操作,包括顺序读写、随机读写、重载(re-write)、读取已写入的数据等。通过这些测试,IOZone 可以帮助用户了解不同文件系统和存储设备的性能特点,从而为选择合适的硬件和…