HBase——使用Put迁移MySql数据到Hbase
先上code:
/** * 功能:迁移mysql上电池历史数据到hbase * Created by liuhuichao on 2016/12/6. */ public class MySqlToHBase { /** * 获取表 * @param tableName * @return * @throws IOException */ private HTable connectHBase(String tableName) throws IOException{ HTable table=null; Configuration conf= HBaseConfiguration.create(); conf.set("hbase.zookeeper.quorum","lhc-centos"); table=new HTable(conf,tableName); return table; } /** * 获取mysql连接 * @return * @throws Exception */ private java.sql.Connection connectDB() throws Exception{ String userName="root"; String password="root"; String url="jdbc:mysql://10.0.1.42:3306/energy?useUnicode=true&characterEncoding=UTF-8"; Class.forName("com.mysql.jdbc.Driver").newInstance(); java.sql.Connection conn=DriverManager .getConnection(url,userName,password); return conn; } /** * 将电池历史数据表中输入导入HBase * @throws Exception */ @Test public void exportFromMySqlToHBase() throws Exception{ java.sql.Connection dbConn=null; HTable table=null; Statement stmt=null; String strQuery="SELECT * FROM `res_battery_data_history` limit 10000,1000000"; dbConn=connectDB();//连接mysql table=connectHBase("batteryDataHistory");//连接HBase try{ stmt=dbConn.createStatement(); ResultSet rs=stmt.executeQuery(strQuery); long beginTime=System.currentTimeMillis();//开始 System.out.println( "beginTime:---"+beginTime); while (rs.next()) { UUID uuid = UUID.randomUUID(); String rowKey = uuid.toString();//作为行健 Put put = new Put(Bytes.toBytes(rowKey)); /** * family:baseData */ // Integer id=rs.getInt("id"); String batteryNo = rs.getString("battery_no"); Integer batteryType = rs.getInt("battery_type"); Float voltageDeviation = rs.getFloat("voltage_deviation"); Float totalVoltage = rs.getFloat("total_voltage"); Float temprature1 = rs.getFloat("temprature1"); Float temprature2 = rs.getFloat("temprature2"); Float chargeNum = rs.getFloat("charge_num"); Float longtitude = rs.getFloat("longtitude"); Float latitude = rs.getFloat("latitude"); Float totalCurrent = rs.getFloat("total_current"); Float soc = rs.getFloat("soc"); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("batteryNo"), Bytes.toBytes(batteryNo)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("batteryType"), Bytes.toBytes(batteryType)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("voltageDeviation"), Bytes.toBytes(voltageDeviation)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("totalVoltage"), Bytes.toBytes(totalVoltage)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("temprature1"), Bytes.toBytes(temprature1)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("temprature2"), Bytes.toBytes(temprature2)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("chargeNum"), Bytes.toBytes(chargeNum)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("longtitude"), Bytes.toBytes(longtitude)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("latitude"), Bytes.toBytes(latitude)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("totalCurrent"), Bytes.toBytes(totalCurrent)); put.add(Bytes.toBytes("baseData"), Bytes.toBytes("soc"), Bytes.toBytes(soc)); /** * family:volumnData */ Float vol1 = rs.getFloat("vol1"); Float vol2 = rs.getFloat("vol2"); Float vol3 = rs.getFloat("vol3"); Float vol4 = rs.getFloat("vol4"); Float vol5 = rs.getFloat("vol5"); Float vol6 = rs.getFloat("vol6"); Float vol7 = rs.getFloat("vol7"); Float vol8 = rs.getFloat("vol8"); Float vol9 = rs.getFloat("vol9"); Float vol10 = rs.getFloat("vol10"); Float vol11 = rs.getFloat("vol11"); Float vol12 = rs.getFloat("vol12"); Float vol13 = rs.getFloat("vol13"); Float vol14 = rs.getFloat("vol14"); Float vol15 = rs.getFloat("vol15"); Float vol16 = rs.getFloat("vol16"); Float vol17 = rs.getFloat("vol17"); Float vol18 = rs.getFloat("vol18"); Float vol19 = rs.getFloat("vol19"); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v1"), Bytes.toBytes(vol1)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v2"), Bytes.toBytes(vol2)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v3"), Bytes.toBytes(vol3)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v4"), Bytes.toBytes(vol4)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v5"), Bytes.toBytes(vol5)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v6"), Bytes.toBytes(vol6)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v7"), Bytes.toBytes(vol7)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v8"), Bytes.toBytes(vol8)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v9"), Bytes.toBytes(vol9)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v10"), Bytes.toBytes(vol10)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v11"), Bytes.toBytes(vol11)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v12"), Bytes.toBytes(vol12)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v13"), Bytes.toBytes(vol13)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v14"), Bytes.toBytes(vol14)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v15"), Bytes.toBytes(vol15)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v16"), Bytes.toBytes(vol16)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v17"), Bytes.toBytes(vol17)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v18"), Bytes.toBytes(vol18)); put.add(Bytes.toBytes("volumnData"), Bytes.toBytes("v19"), Bytes.toBytes(vol19)); /** * family:extraData */ String remarks = rs.getString("remarks"); String testUserName = rs.getString("test_user_name"); String createTime = rs.getString("create_time"); Integer createUser = rs.getInt("create_user"); Integer source = rs.getInt("source"); put.add(Bytes.toBytes("extraData"), Bytes.toBytes("remarks"), Bytes.toBytes(remarks)); put.add(Bytes.toBytes("extraData"), Bytes.toBytes("testUserName"), Bytes.toBytes(testUserName)); put.add(Bytes.toBytes("extraData"), Bytes.toBytes("createTime"), Bytes.toBytes(createTime)); put.add(Bytes.toBytes("extraData"), Bytes.toBytes("createUser"), Bytes.toBytes(createUser)); put.add(Bytes.toBytes("extraData"), Bytes.toBytes("source"), Bytes.toBytes(source)); table.put(put); } }catch (Exception e){ e.printStackTrace(); } finally { try{ if(stmt !=null){ stmt.close(); } if(dbConn !=null){ dbConn.close(); } if(table!=null){ table.close(); } long endTime=System.currentTimeMillis();//开始 System.out.println( "endTime:---"+endTime); }catch(Exception e){ e.printStackTrace(); } } } }
结果:10000 row(s) in 218.0310 seconds
(我是单机版的HBase,未使用HDFS做底层存储。)
刚开始的sql没有加limit,直接上来把测试表里面的三百多万条直接插出来,结果还没查完,就堆栈溢出了;额。。。后来先塞了一万条到HBase,额,还好,速度很快,但是感觉这种导入方式不具有通用性,对于大量数据的导入是不ok的。
HBase——使用Put迁移MySql数据到Hbase的更多相关文章
- Sqoop导入mysql数据到Hbase
sqoop import --driver com.mysql.jdbc.Driver --connect "jdbc:mysql://11.143.18.29:3306/db_1" ...
- Sqoop将mysql数据导入hbase的血与泪
Sqoop将mysql数据导入hbase的血与泪(整整搞了大半天) 版权声明:本文为yunshuxueyuan原创文章.如需转载请标明出处: https://my.oschina.net/yunsh ...
- 迁移mysql数据到oracle上
转自:http://www.cnblogs.com/Warmsunshine/p/4651283.html 我是生成的文件里面的master.sql里面的sql,一个一个拷出来的. 迁移mysql数据 ...
- Linux Centos 迁移Mysql 数据位置
Linux Centos 迁移Mysql 数据位置 由于业务量增加导致安装在系统盘(20G)磁盘空间被占满了, 现在进行数据库的迁移. Mysql 是通过 yum 安装的. Centos6.5Mysq ...
- sqoop将mysql数据导入hbase、hive的常见异常处理
原创不易,如需转载,请注明出处https://www.cnblogs.com/baixianlong/p/10700700.html,否则将追究法律责任!!! 一.需求: 1.将以下这张表(test_ ...
- flink-cdc同步mysql数据到hbase
本文首发于我的个人博客网站 等待下一个秋-Flink 什么是CDC? CDC是(Change Data Capture 变更数据获取)的简称.核心思想是,监测并捕获数据库的变动(包括数据 或 数据表的 ...
- hbase 从hdfs上读取数据到hbase中
<dependencies> <dependency> <groupId>org.apache.hbase</groupId> <artifact ...
- Python迁移MySQL数据到MongoDB脚本
MongoDB是一个文档数据库,在存储小文件方面存在天然优势.随着业务求的变化,需要将线上MySQL数据库中的行记录,导入到MongoDB中文档记录. 一.场景:线上MySQL数据库某表迁移到Mong ...
- 使用Navicat迁移MySQL数据至Oracle时大小写原因报“表或视图不存在”问题处理
使用Navicat提供的数据传输工具将JEECMSv9的MySQL的数据迁移至Oracle数据库,数据迁移成功表都存在,但是在程序启动时提示表或视图不存在. Caused by: java.sql.S ...
随机推荐
- webstorm中导入git项目
1.打开webStrom 配置git File–setting
- windows下注册和取消pg服务的命令
pg_ctl register [-N servicename] [-U username] [-P password] [-D datadir] [-w][-t seconds] [-o optio ...
- 【[CQOI2011]动态逆序对】
这是我的第一个数据结构套数据结构 不是线段树套\(Splay\),而是非常蛇皮的块状链表套树状数组 如果这里按照\(\sqrt{n}\)的大小来分块,那么就需要\(n\sqrt{n}\)的空间,可能开 ...
- Dubbo实践(二)架构
架构 节点角色说明 节点 角色说明 Provider 暴露服务的服务提供方 Consumer 调用远程服务的服务消费方 Registry 服务注册与发现的注册中心 Monitor 统计服务的调用次数和 ...
- PAT——1037. 在霍格沃茨找零钱
如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特(Knut)兑一个西可,很容易.”现在,给定 ...
- 【luogu P3953 逛公园】 题解
题目链接:https://www.luogu.org/problemnew/show/P3953 题外话:感觉2017年神题好多..这还不是最神的一道,真在考场上我也就写个最短路计数暴力了.现在在大佬 ...
- emmet完整收录(html,css)
emmet官网 https://emmet.io/ 语法篇 Child: > nav>ul>li <nav> <ul> <li></li&g ...
- java 企业门户网站 源码 自适应响应式 freemarker 静态引擎 html5 SSM
官网 http://www.fhadmin.org/ 系统介绍: 1.网站后台采用主流的 SSM 框架 jsp JSTL,网站后台采用freemaker静态化模版引擎生成html 2.因为是生成的ht ...
- functional filter()
#include "pch.h" #include <iostream> #include <deque> #include <string> ...
- LVM的创建与管理
LVM的创建与管理1.创建物理分区 fdisk 或者 parted 工具分区. LVM分区的类型ID为8e2.创建物理卷 pvcreate 磁盘分区或整个磁盘3.创建卷组 vgcreate 卷组 ...