2014-01-26 09:37:38
来公司快半年了,还有几天就快回家了,好开心。今天我准备梳理下redis的相关内容。
1.Redis是什么
简单来讲,Redis就是一个key-value数据库,适合所有数据in-memory的场景。
2.Redis常用数据类型
Redis最常用的数据类型主要是下面5种:
3.Redis里可以有表么
在使用redis的时候,会和使用sql表有很大区别,我们没有语句去操控redis服务,有的仅仅是一些简单的命令。这些命令是数据类型敏感的,比如我们把set命令使用在list上,就会得到一个错误。我们来考虑一个简单的sql表。
id | username | password | name | surname |
1 | user1 | pass1 | Bob | Smith |
2 | user2 | pass2 | Mario | Rossi |
我们如何才能把这个简单的sql表存到Redis中呢?在sql结构中,我们可以使用select id的方式,获取一个记录的所有内容。所以,就有了下面这种存储方式。
Key | Value |
---|---|
user:1:username | user1 |
user:1:password | pass1 |
user:1:name | Bob |
user:1:surname | Smith |
user:2:username | user2 |
user:2:password | pass2 |
user:2:name | Mario |
user:2:surname | Rossi |
现在,给定一个用户的id,我们就可以通过 user:1:username,user:1:password,user:1:name,user:1:surname1这种方式去获取所有数据了。
如果上面的数据用来支持一个登陆程序,则给定一个用户名,我们也需要去获取整条纪录的信息。这时候最好的方式是建立一个映射关系user-id。即给我们的数据设计添加一个keys, user:username:id。
Key | Value |
---|---|
user:user1:id | 1 |
user:user2:id | 2 |
所以,如果此时Mario Rossi登陆我们的系统,我们就可以根据他提供的用户名获取id,从而获取他的整个用户信息。
另外一个问题是,我们如何去保证主键的唯一性。在sql世界中,我们可以通过 "id int primary key auto_increment",的方式解决主键问题。在Redis中,我们对应的解决方式是增加一个keys:"user:next_id",把这个key作为一个counter,当我们新增一个user时,可以通过INCR command来手动获取这个id。
在sql中,如果 select * from users:就可以获取整张表的数据。为了实现这个功能,我们可以怎么做呢?也许你会觉得,上面的规则,已经足够我们获取所有的数据了。通过0到user:next_id的所有ids,就可以了。但是如果有用户数据被删除了,我们就不能按照上面的做法来做了。
比较好的解决方式是再增加一个key, user:list 用来存储所有在用的记录的id。不用的id,就直接从这个list里删掉。
最后,当我们删除一个用户的时候,我们需要删除 all the keys user:id:*, user:username:id and the id in "user:list".