hive分析后如何录入mysql(hive从mysql导入数据量变多的解决方案)
hive分析后如何录入mysql
hive从mysql导入数据量变多的解决方案原始导数命令:
|
bin/sqoop import - connect jdbc:mysql://192.168.169.128:3306/yubei -username root - password 123456 - table yl_city_mgr_evt_info --split-by rec_id -m 4 --fields-terminated-by "\t" --lines-terminated-by "\n" --hive-import --hive-overwrite -create-hive-table -delete-target-dir -hive-database default -hive-table yl_city_mgr_evt_info |
原因分析:可能是mysql中字段里面有'\n'等分隔符,导入hive时默认以'n'作换行符,导致hive中的记录数变多。
解决方法:
导入数据时加上--hive-drop-import-delims选项,会删除字段中的\n,\r,\01。
最终导数命令:
|
bin/sqoop import - connect jdbc:mysql://192.168.169.128:3306/yubei -username root - password 123456 - table yl_city_mgr_evt_info --split-by rec_id -m 4 --hive-drop-import-delims --fields-terminated-by "\t" --lines-terminated-by "\n" --hive-import --hive-overwrite -create-hive-table -delete-target-dir -hive-database default -hive-table yl_city_mgr_evt_info |
参考官方文档:https://sqoop.apache.org/docs/1.4.7/SqoopUserGuide.html
补充:Sqoop导入MySQL数据到Hive遇到的坑
1.sqoop导入到HDFS
1.1执行sqoop job,会自动更新last value
|
# sqoop 增量导入脚本 bin/sqoop job --create sqoop_hdfs_test02 -- import \ --connect jdbc:mysql://localhost:3306/pactera_test \ --username root \ --password 123456 \ --table student \ --target-dir /user/sqoop/test002/ \ --fields-terminated-by "\t" \ --check-column last_modified \ --incremental lastmodified \ --last-value "2018-12-12 00:03:00" \ --append |
说明:--append 参数是必须的,要不然第二次运行job 会报错,如下:
至此,sqoop job 已建设完毕!
2.Hive创建表,并读取sqoop导入的数据
|
create external table if not exists student_hive (SId int ,Sname string ,Sage string,Ssex string , last_modified Timestamp ) row format delimited fields terminated by '\t' location 'hdfs://node01:8020/user/sqoop/test002/' ; |
注意:此处hive中时间的格式为timestamp,设置为date DB数据无法正常加载。
第一次全量加载,整条路线完全OK,hive表可以查询到数据。
-----------------------重点分割线-----------------------
* sqoop lastmodified格式的增量加载,会将last-value 保存为job执行的系统时间,若测试数据库的check-column 小于当前系统时间(即上一个job的last-value),则数据将不被加载。
如SId=6 就没有被加载,遂改为今日时间(2018-12-26 17:05)进行数据测试,数据成功被加载!哟呵!!
总结:
使用lastmodified格式,进行sqoop增量导入时,
1.注意--append的使用;
2.last-value为job运行的系统时间,在数据测试时,要保证数据的准确,数据的自增长。
3.一切皆有定数,查看资料,准确定位自己系统遇到的问题
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://www.cnblogs.com/cqdxwjd/p/12980776.html
- mysql索引面试总结(Mysql数据库索引面试题程序员基础技能)
- mysql按端口查找配置(MySQL中给定父行找到所有子行的解决方案)
- mysql索引原理及使用(再有人问你MySQL索引原理,就把这篇文章甩给他!)
- ubuntu20.2安装mysql(Ubuntu 14.04下mysql安装配置教程)
- 查看mysql支持的字符集(不可忽视的MySQL字符集)
- mysql常见的存储引擎(如何选择MySQL的存储引擎?)
- mysql的字符串截取函数(MySQL实现字符串的拼接,截取,替换,查找位置的操作)
- mysqldecimal类型数据转换(mysql decimal数据类型转换的实现)
- mysql的三种模式(详解 MySQL的FreeList机制)
- apache搭建php环境(Windows上安装Apache2、PHP5、MySQL5及与Resin配合实现多系统之整合)
- mysql插入数据错误代码(教你解决往mysql数据库中存入汉字报错的方法)
- mysql有哪些索引和聚簇索引(MySQL 独立索引和联合索引的选择)
- MYSQL中GROUP BY不包含所有的非聚合字段时的注意事项
- SQL SERVER与MySQL数据类型的对应关系
- mysql不兼容问题(解决mysql 组合AND和OR带来的问题)
- mysql查看视图注释(详解MySQL的sql_mode查询与设置)
- 小米音乐与 QQ 音乐合作,便捷迁移会员(小米音乐与QQ音乐合作)
- 小米推出米兔儿童电话手表奥特曼版,799 元,支持微信 QQ(小米推出米兔儿童电话手表奥特曼版)
- 贾怀胤唱《白龙马》 炸场 了 没想到京剧还能这么玩(贾怀胤唱白龙马)
- 白龙马的改编学生版,快来看看(白龙马的改编学生版)
- 萌娃唱《白龙马》走红,那生动的小表情,网友直呼 简直是戏精(萌娃唱白龙马走红)
- 朱鹤松被不断认可,凤凰传奇玲花喊话岳云鹏,索要老朱演出门票(朱鹤松被不断认可)
热门推荐
- docker镜像实例(Docker的镜像制作与整套项目一键打包部署的实现)
- linux用nvm安装nodejs(nodejs管理工具nvm安装过程详解)
- jquery实现标签输入功能
- dedecms制作的网站如何发布(DedeCms后台添加编辑文章空白的解决方法)
- dedecms操作手册(织梦DEDECMS结构化数据Meta申明标签)
- pythonfor循环如何遍历嵌套列表(在Python中,不用while和for循环遍历列表的实例)
- python 内存读写(详解python持久化文件读写)
- php cgi是什么意思(PHP7内核CGI与FastCGI详解)
- 阿里云服务器加载镜像操作手册(阿里云、腾讯云、小鸟云服务器中安装wdcp图文教程)
- win7如何搭建php环境(阿里云Win2016安装Apache和PHP环境图文教程)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9