redis 键值设计

  • 时间:
  • 浏览:1
  • 来源:跟我学网络

最后发布:2017-06-19 18:13:57首次发布:2017-06-19 18:13:57

http://blog.csdn.net/shikaiwencn/article/details/51792059

[quote]

丰富的数据结构使得Redis的设计非常的有趣。不像关系型数据库那样,DEV和DBA需要深度沟通,review每行sql语句,也不像memcached那样,不需要DBA的参与。redis的DBA需要熟悉数据结构,并能了解使用场景。

下面举一些常见适合kv数据库的例子来谈谈键值的设计,并与关系型数据库做一个对比,发现关系型的不足之处。

用户登录系统

记录用户登录信息的一个系统, 我们简化业务后只留下一张表。

关系型数据库的设计

mysql> select * from login;

--------- ---------------- ------------- ---------------------

| user_id | name | login_times | last_login_time |

--------- ---------------- ------------- ---------------------

| 1 | ken thompson | 5 | 2011-01-01 00:00:00 |

| 2 | dennis ritchie | 1 | 2011-02-01 00:00:00 |

| 3 | Joe Armstrong | 2 | 2011-03-01 00:00:00 |

--------- ---------------- ------------- ---------------------

user_id表的主键,name表示用户名,login_times表示该用户的登录次数,每次用户登录后,login_times会自增,而last_login_time更新为当前时间。

REDIS的设计

关系型数据转化为KV数据库,我的方法如下:

key 表名:主键值:列名

value 列值

一般使用冒号做分割符,这是不成文的规矩。比如在PHP-admin for redis系统里,就是默认以冒号分割,于是user:1 user:2等key会分成一组。于是以上的关系数据转化成kv数据后记录如下:

Set login:1:login_times 5

Set login:2:login_times 1

Set login:3:login_times 2

Set login:1:last_login_time 2011-1-1

Set login:2:last_login_time 2011-2-1

Set login:3:last_login_time 2011-3-1

set login:1:name ”ken thompson“

set login:2:name “dennis ritchie”

set login:3:name ”Joe Armstrong“

[/quote]