【Hive】【HiveQL】【大数据技术基础】 实验四 HBase shell命令实验

news2024/12/23 8:41:17

实验四:熟悉常用的HBase操作

实验概览

        在本次实验中,我们将深入探索HBase在Hadoop生态系统中的角色,并熟练掌握常用的HBase Shell命令和Java API操作。通过这些实践,我们能够更好地理解HBase的工作原理以及如何在实际项目中应用。

实验目的

1. 理解HBase在Hadoop体系结构中的角色;

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

3. 熟悉HBase操作常用的Java API。

实验平台

操作系统:Linux

Hadoop版本:1.2.1或以上版本

HBase版本:0.98.9

JDK版本:1.6或以上版本

Java IDE:Eclipse

实验内容和要求

用Hadoop提供的HBase Shell命令完成以下任务:

HBase Shell命令操作

  1. 列出所有表:使用list命令查看HBase中所有表的相关信息,如表名和表结构。

  2. 打印表记录:使用scan命令在终端打印指定表的所有记录数据。

  3. 添加和删除列族或列:使用put命令向已创建的表添加数据,以及删除指定的列族或列。

  4. 清空表记录:使用truncate命令清空指定表的所有记录数据。

  5. 统计表行数:使用count命令统计表的行数。

关系型数据库到HBase的数据迁移

        我们将关系型数据库中的表和数据转换为适合HBase存储的表,并插入数据。以下是涉及的表和数据:

学生表(Student)

学号(S_No)

姓名(S_Name)

性别(S_Sex)

年龄(S_Age)

2015001

Zhangsan

male

23

2015003

Mary

female

22

2015003

Lisi

male

24

课程表(Course)

课程号(C_No)

课程名(C_Name)

学分(C_Credit)

123001

Math

2.0

123002

Computer Science

5.0

123003

English

3.0

选课表(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

HBase表创建与数据操作

同时,请完成以下指定功能:

(1)创建以上表

create 'Student', 'info'

create 'Course', 'details'

create 'SC', 'record'

(2)在多个表添加3行(学生)

插入学生表数据:

put 'Student', '2015001', 'info:S_No', '2015001'

put 'Student', '2015001', 'info:S_Name', 'Zhangsan'

put 'Student', '2015001', 'info:S_Sex', 'male'

put 'Student', '2015001', 'info:S_Age', '23'

put 'Student', '2015002', 'info:S_No', '2015002'

put 'Student', '2015002', 'info:S_Name', 'Mary'

put 'Student', '2015002', 'info:S_Sex', 'female'

put 'Student', '2015002', 'info:S_Age', '22'

put 'Student', '2015003', 'info:S_No', '2015003'

put 'Student', '2015003', 'info:S_Name', 'Lisi'

put 'Student', '2015003', 'info:S_Sex', 'male'

put 'Student', '2015003', 'info:S_Age', '24'

插入课程表数据:

put 'Course', '123001', 'details:C_No', '123001'

put 'Course', '123001', 'details:C_Name', 'Math'

put 'Course', '123001', 'details:C_Credit', '2.0'

put 'Course', '123002', 'details:C_No', '123002'

put 'Course', '123002', 'details:C_Name', 'Computer Science'

put 'Course', '123002', 'details:C_Credit', '5.0'

put 'Course', '123003', 'details:C_No', '123003'

put 'Course', '123003', 'details:C_Name', 'English'

put 'Course', '123003', 'details:C_Credit', '3.0'

插入选课表数据:

put 'SC', '2015001123001', 'record:SC_Sno', '2015001'

put 'SC', '2015001123001', 'record:SC_Cno', '123001'

put 'SC', '2015001123001', 'record:SC_Score', '86'

put 'SC', '2015001123003', 'record:SC_Sno', '2015001'

put 'SC', '2015001123003', 'record:SC_Cno', '123003'

put 'SC', '2015001123003', 'record:SC_Score', '69'

put 'SC', '2015002123002', 'record:SC_Sno', '2015002'

put 'SC', '2015002123002', 'record:SC_Cno', '123002'

put 'SC', '2015002123002', 'record:SC_Score', '77'

进行部分结果展示:

(3)在多个表中修改指定的行指定列的数据

put 'Student', '2015001', 'info:S_Age', '24'

(4)在多个表删除表指定的行的记录

删除学生表中的一行数据:

deleteall 'Student', '2015001'

删除选课表中的一个单元格数据:

delete 'SC', '2015001123001', 'record:SC_Score'

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

3D意识(3D Awareness)浅析

一、简介 3D意识(3D Awareness)主要是指视觉基础模型(visual foundation models)对于3D结构的意识或感知能力,即这些模型在处理2D图像时是否能够理解和表示出图像中物体或场景的3D结构,其具体体现在编码场景…

快递面单批量导入打印软件小程序下载 佳易王网店快递面单批量打印管理系统操作教程

一、概述 【软件文件资源在文章最后】 快递面单批量导入打印软件小程序下载 快递面单批量打印管理系统操作教程 直接使用快递空白单打印,可以扫描条码并可以查询快递信息,面单内容可以自定义。 可以批量导入批量打印,从而提高效率节省时间…

缓冲区溢出,数据被踩的案例学习

继续在ubuntu上学习GDB,今天要学习的是缓冲区溢出。 程序的地址: GitHub - gedulab/gebypass: bypass password by heap buffer overflow 编译的方法: gcc -g -O2 -o gebypass gebypass.c 照例设置一下科学shangwang代理: e…

数据库SQL——连接表达式(JOIN)图解

目录 一、基本概念 二、常见类型 内连接(INNER JOIN): 左连接(LEFT JOIN 或 LEFT OUTER JOIN): 右连接(RIGHT JOIN 或 RIGHT OUTER JOIN): 全连接(FULL…

sql注入之二次注入(sqlilabs-less24)

二阶注入(Second-Order Injection)是一种特殊的 SQL 注入攻击,通常发生在用户输入的数据首先被存储在数据库中,然后在后续的操作中被使用时,触发了注入漏洞。与传统的 SQL 注入(直接注入)不同&a…

查询DBA_FREE_SPACE缓慢问题

这个是一个常见的问题,理论上应该也算是一个bug,在oracle10g,到19c,我都曾经遇到过;今天在给两套新建的19C RAC添加监控脚本时,又发现了这个问题,在这里记录一下。 Symptoms 环境:…

实验6记录网络与故障排除

实验6记录网络与故障排除 实验目的及要求: 通过实验,掌握如何利用文档记录网络设备相关信息并完成网络拓扑结构的绘制。能够使用各种技术和工具来找出连通性问题,使用文档来指导故障排除工作,确定具体的网络问题,实施…

「QT」文件类 之 QTextStream 文本流类

✨博客主页何曾参静谧的博客📌文章专栏「QT」QT5程序设计📚全部专栏「Win」Windows程序设计「IDE」集成开发环境「UG/NX」BlockUI集合「C/C」C/C程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「UG/NX」NX定制…

【go从零单排】JSON序列化和反序列化

🌈Don’t worry , just coding! 内耗与overthinking只会削弱你的精力,虚度你的光阴,每天迈出一小步,回头时发现已经走了很远。 📗概念 在 Go 语言中,处理 JSON 数据主要依赖于 encoding/json 包。这个包提…

网络学习第四篇

引言: 我们在第三篇的时候出现了错误,我们要就行排错,那么我们要知道一下怎么配置静态路由实现ping通,这样子我们才知道下一跳到底是什么,为什么这样子做。 实验目的 理解和掌握静态路由的基本概念和配置方法。 实…

蓝桥杯竞赛单片机组备赛【经验帖】

本人获奖情况说明 笔者本人曾参加过两次蓝桥杯电子赛,在第十二届蓝桥杯大赛单片机设计与开发组获得省级一等奖和国家级二等奖,在第十五届嵌入式设计开发组获得省级二等奖。如果跟着本帖的流程备赛,只要认真勤奋,拿个省二绝对没问…

yolo标签自动标注(使用python和yolo方法)

yolo代码自动标注 1.引言1.初阶“自动标注”,给每个图像都生成一个固定的标注文件,进而在labglimg中对矩形框进行微调,减少标注的工作量2.高阶自动标注,利用我们训练好的(但是没有特别精准的)yolo文件先对每…

Git在版本控制中的应用

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 Git在版本控制中的应用 Git在版本控制中的应用 Git在版本控制中的应用 引言 Git 概述 定义与原理 发展历程 Git 的关键技术 分布…

vue2.7.14 + vant + vue cli脚手架转vite启动运行问题记录

文章目录 前言方案一(借用插件转换)启动命令,转换方案一转换遇到的问题 方案二(手动调整)方案两者对比小结 前言 vue cli 脚手架转成vite启动 简单说说这个项目的一些底层基本结构哈,以及写这篇博客的目的…

边缘提取函数 [OPENCV--2]

OPENCV中最常用的边界检测是CANNY函数 下面展示它的用法 通常输入一个灰度图像(边界一般和颜色无关)这样也可以简化运算cv::Canny(inmat , outmat , therhold1, therhold2 ) 第一个参数是输入的灰度图像,第二个是输出的图像这两个参数都是引用…

SpringBoot基础系列学习(七):整合Mybatis

文章目录 一丶介绍1.基本信息2.特性 二丶代码1.项目结构2.数据表3.引入依赖4.实体类5.mapper6.sql.xml7.Controller8.结果 一丶介绍 1.基本信息 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手…

什么岗位需要学习 OpenGL ES ?说说 3.X 的新特性

什么是 OpenGL ES OpenGL ES 是一种为嵌入式系统和移动设备设计的3D图形API(应用程序编程接口)。它是标准 OpenGL 3D 图形库的一个子集,专门为资源受限的环境(如手机、平板电脑、游戏机和其他便携式设备)进行了优化。 由于其在移动设备上的广泛适用性,OpenGL ES是学习移…

记一次谷歌chrome浏览器 18 以上和 18 以下,最小字号不一致,导致的样式兼容问题解决过程

**记录一次谷歌chrome浏览器 18 以上和 18 以下,最小字号不一致,导致的样式兼容问题解决过程:** 定位问题尝试解决方案第一时间想到的解决方案:方案一尝试方案二:scale 缩放方案三:rem、em测试 方案四 SVG最…

Elasticsearch 和 Kibana 8.16:Kibana 获得上下文和 BBQ 速度并节省开支!

作者:来自 Elastic Platform Product Team Elastic Search AI 平台(Elasticsearch、Kibana 和机器学习)的 8.16 版本包含大量新功能,可提高性能、优化工作流程和简化数据管理。 使用更好的二进制量化 (Better Binary Quantizatio…

HarmonyOS Next星河版笔记--界面开发(5)

1.字符串 1.1.字符串拼接 作用:把两个或多个字符串,拼成一个字符串。(通常是用来拼接字符串和变量) hello world > helloworld 加好作用:拼接 let name:string 小明 console.log(简介信息,名字是 name) …