我是靠谱客的博主 朴素烧鹅,最近开发中收集的这篇文章主要介绍hive mysql互导_利用Sqoop实现Hive的数据与MySQL数据的互导,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1. 配置概览

Hive arguments:

--create-hive-table Fail if the target hive table exists

--hive-database Sets the database name to use when importing to hive

--hive-delims-replacement Replace Hive record x01 and row delimiters (nr) from imported string fields with user-defined string

--hive-drop-import-delims Drop Hive record x01 and row delimiters (nr) from imported string fields

--hive-home

--hive-import

--hive-overwrite Overwrite existing data in the Hive table

--hive-partition-key Sets the partition key to use when importing to hive

--hive-partition-value Sets the partition value to use when importing to hive

--hive-table Sets the table name to use when importing to hive

--map-column-hive Override mapping for specific column to hive types.

2. 把MySQL表中数据导入到hive表中

drop table if exists hive_users;

create table hive_users (id string,name string,age int)

ROW FORMAT DELIMITED

FIELDS TERMINATED BY 't';

[root@repo bin]# ./sqoop import

--connect jdbc:mysql://192.168.9.100:3306/test

--username root

--password 123456

--table users

--fields-terminated-by 't'

--num-mappers 1

--hive-import

--hive-database default

--hive-table hive_users

--delete-target-dir

hive> select * from hive_users;

OK

1 Jed 15

2 Tom 16

3 Tony 17

4 Bob 18

5 Harry 19

6 Jack 20

3. 把hive表中数据导入到MySQL表中

mysql> create table users_from_hive (id int,name varchar(10),age int,primary key (`id`));

[root@repo bin]# ./sqoop export

--connect jdbc:mysql://192.168.9.100:3306/test

--username root

--password 123456

--table users_from_hive

--input-fields-terminated-by 't'

--export-dir /hive_single_user/warehouse/hive_users

--num-mappers 1

mysql> select * from users_from_hive;

+----+-------+------+

| id | name | age |

+----+-------+------+

| 1 | Jed | 15 |

| 2 | Tom | 16 |

| 3 | Tony | 17 |

| 4 | Bob | 18 |

| 5 | Harry | 19 |

| 6 | Jack | 20 |

+----+-------+------+

注意:

在sqoop-1.4.6以前,从MySQL中导出数据到hive表中,不能指定文件格式为parquet,只能先导入到HDFS,在从HDFS上load parquet file

4. 把sqoop命令写到文件中,sqoop执行时使用这个文件来执行命令

[root@repo myshell]# vim sqoop-options-test

--connect jdbc:mysql://192.168.9.100:3306/test

--username root

--password 123456

--target-dir /user/root/SQOOP/import/users_options

--num-mappers 1

[root@repo bin]# ./sqoop import

--options-file /root/myshell/sqoop-options-test

--table users_from_hive

[root@repo bin]# hdfs dfs -cat /user/root/SQOOP/import/users_options/*

1,Jed,15

2,Tom,16

3,Tony,17

4,Bob,18

5,Harry,19

6,Jack,20

注意:

(1) 选项在文件中与手工设定可以同时使用

(2) 可以在选项文件中写注释,# …

最后

以上就是朴素烧鹅为你收集整理的hive mysql互导_利用Sqoop实现Hive的数据与MySQL数据的互导的全部内容,希望文章能够帮你解决hive mysql互导_利用Sqoop实现Hive的数据与MySQL数据的互导所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部