redis 键值设计

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

引用

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

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

用户登录系统

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

关系型数据库的设计

mysql>select*fromlogin;

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

|user_id|name|login_times|last_login_time|

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

|1|kenthompson|5|2011-01-0100:00:00|

|2|dennisritchie|1|2011-02-0100:00:00|

|3|JoeArmstrong|2|2011-03-0100:00:00|

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

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

REDIS的设计

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

key表名:主键值:列名

value列值

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

Setlogin:1:login_times5

Setlogin:2:login_times1

Setlogin:3:login_times2

Setlogin:1:last_login_time2011-1-1

Setlogin:2:last_login_time2011-2-1

Setlogin:3:last_login_time2011-3-1

setlogin:1:name”kenthompson“

setlogin:2:name“dennisritchie”

setlogin:3:name”JoeArmstrong“

相关推荐