首页 > 数据库技术 > 详细

一步完成 MySQL 向 Redis 迁移

时间:2016-03-10 14:52:37      阅读:256      评论:0      收藏:0      [点我收藏+]

参考国外大牛的方法,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 迁移

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!