Kettle 远程mysql 表导入到 hadoop hive

kettle 远程mysql 表导入到 hadoop hive

(教学用 )

文章目录

  • [kettle 远程mysql 表导入到 hadoop hive](#kettle 远程mysql 表导入到 hadoop hive)
  • [创建 对象 执行 SQL 语句 -mysql 导出 CSV格式](#创建 对象 执行 SQL 语句 -mysql 导出 CSV格式)
  • [CSV 文件远程上传到 HDFS](#CSV 文件远程上传到 HDFS)
    • [运行 SSH 命令](#运行 SSH 命令)
    • [远程登录 run SSH 并执行 hadoop fs -put](#远程登录 run SSH 并执行 hadoop fs -put)
  • 建表和加载数据
  • 总结

创建 对象 执行 SQL 语句 -mysql 导出 CSV格式

sql 复制代码
SELECT * 
INTO OUTFILE '/home/mysql-files/sakila_actor9.csv' 
FIELDS TERMINATED BY ',' 
ENCLOSED BY '' 
LINES TERMINATED BY '\n'
FROM sakila.actor;

CSV 文件远程上传到 HDFS

运行 SSH 命令

远程登录 run SSH 并执行 hadoop fs -put


bash 复制代码
/opt/module/hadoop-3.3.0/bin/hadoop fs -put /home/mysql-files/sakila_actor9.csv /user/hive/warehouse/

建表和加载数据

sql 复制代码
CREATE EXTERNAL TABLE IF NOT EXISTS sakiladb.actor9 
(
  actor_id STRING COMMENT 'from deserializer',
  first_name STRING COMMENT 'from deserializer',
  last_name STRING COMMENT 'from deserializer',
  last_update STRING COMMENT 'from deserializer'
)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','  -- 列分隔符
STORED AS TEXTFILE;

LOAD DATA INPATH '/user/hive/warehouse/sakila_actor9.csv' INTO TABLE actor9;

总结

通过 Kettle (Pentaho Data Integration),我们能够轻松地将远程 MySQL 数据库中的数据导出到 CSV 文件,上传到 HDFS,并最终将数据导入 Hive。这样,我们可以利用 Hadoop 的强大计算能力来进行数据处理和分析。以下是整个过程的概览:

导出 MySQL 数据为 CSV 格式:使用 Table Input 和 Text File Output 步骤。

上传 CSV 文件到 HDFS:通过 SSH Connection 执行 hadoop fs -put 命令。

在 Hive 中创建表并加载数据:使用 CREATE TABLE 和 LOAD DATA 命令。

这个过程不仅适用于 MySQL 和 Hive,也可以根据需要适配其他数据源和目标系统。

相关推荐
猫头虎6 小时前
基于信创openEuler系统安装部署OpenTeleDB开源数据库的实战教程
数据库·redis·sql·mysql·开源·nosql·database
Nandeska6 小时前
17、MySQL InnoDB ReplicaSet
数据库·mysql
hlABgYML6 小时前
基于NGSIM数据的Wiedemann99跟驰模型标定
mysql
墨理学AI7 小时前
一文学会一点python数据分析-小白原地进阶(mysql 安装 - mysql - python 数据分析 - 学习阶段梳理)
python·mysql·数据分析
洛豳枭薰7 小时前
MySQL 并行复制
数据库·mysql
无级程序员7 小时前
大数据Hive之拉链表增量取数合并设计(主表加历史表合并成拉链表)
大数据·hive·hadoop
纤纡.7 小时前
Linux 下 MySQL 数据类型与约束:第三章核心表格归纳与实战应用
linux·mysql
czlczl200209257 小时前
增删改查时如何提高Mysql与Redis的一致性
数据库·redis·mysql
打工的小王7 小时前
MySql(二)索引
数据库·mysql
luoluoal8 小时前
基于python的医疗问句中的实体识别算法的研究(源码+文档)
python·mysql·django·毕业设计·源码