码迷,mamicode.com
首页 > 数据库 > 详细

一步完成 MySQL 向 Redis 迁移

时间:2016-03-10 14:55:08      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:mysql   迁移   redis   

参考国外大牛的方法,http://www.oschina.net/translate/mysql-to-redis-in-one-step

实验成功,以下是操作方法:

MySQL表结构数据

[test]> select * from hechunyang;
+----+--------+---------+
| id | myname | mymoney |
+----+--------+---------+
|  1 | aa     |    1000 |
|  2 | bb     |    2000 |
+----+--------+---------+
2 rows in set (0.00 sec)


编辑迁移SQL脚本

cat mysql_to_redis.sql
SELECT CONCAT( 
  "*4\r\n", 
  ‘$‘, LENGTH(redis_cmd), ‘\r\n‘, 
  redis_cmd, ‘\r\n‘, 
  ‘$‘, LENGTH(redis_key), ‘\r\n‘, 
  redis_key, ‘\r\n‘, 
  ‘$‘, LENGTH(hkey), ‘\r\n‘, 
  hkey, ‘\r\n‘, 
  ‘$‘, LENGTH(hval), ‘\r\n‘, 
  hval, ‘\r‘ 

FROM ( 
  SELECT 
  ‘HSET‘ AS redis_cmd, 
  ‘keyname‘ AS redis_key, 
  myname AS hkey, 
  mymoney AS hval 
  FROM hechunyang 
) AS t;


一步完成 MySQL 向 Redis 迁移

mysql test --skip-column-names --raw < mysql_to_redis.sql | redis-cli --pipe
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 2


Redis查看数据
127.0.0.1:6379> keys *
1) "keyname"
127.0.0.1:6379> hkeys keyname
1) "aa"
2) "bb"
127.0.0.1:6379> hget keyname aa
"1000"
127.0.0.1:6379> hget keyname bb
"2000"


本文出自 “贺春旸的技术专栏” 博客,请务必保留此出处http://hcymysql.blog.51cto.com/5223301/1749526

一步完成 MySQL 向 Redis 迁移

标签:mysql   迁移   redis   

原文地址:http://hcymysql.blog.51cto.com/5223301/1749526

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!