您的位置:首页 > 理论基础 > 数据结构算法

Redis 数据结构

2013-05-30 23:45 363 查看
开始接触接触redis!

Redis并不是简单的key-value存储,实际上他是一个数据结构服务器,支持不同类型的值 ,除了字符串当做键所指向的值之外,还包含以下几种类型:
二进制安全的 字符串 string
二进制安全的 字符串列表 list of string
二进制安全的 字符串 集合 setof string

有序集合 sorted set of string,其中每个元素都有一个socre,根据该socre进行排序
简单使用:
字符串类型:

$ redis-cli set mykey "my binary safe value"
OK
$ redis-cli get mykey
my binary safe value
可以通过 set get 命令来设置和获取值;
$ redis-cli set counter 100
OK $ redis-cli incr counter
(integer) 101
$ redis-cli incr counter
(integer) 102
$ redis-cli incrby counter 10
(integer) 112
可以通过INCR命令将字符串解析为数值类型;

列表类型
Redis lists基于Linked Lists实现。这意味着即使在一个list中有数百万个元素,在头部或尾部添加一个元素的操作,其时间复杂度也是常数级别的。用LPUSH命令在十个元素的list头部添加新元素,和在千万元素list头部添加新元素的速度相同。
$ redis-cli rpush messages "Hello how are you?"
OK
$ redis-cli rpush messages "Fine thanks. I‘m having fun with Redis"
OK
$ redis-cli rpush messages "I should look into this NOSQL thing ASAP"
OK
$ redis-cli lrange messages 0 2
1. Hello how are you?
2. Fine thanks. I‘m having fun with Redis
3. I should look into this NOSQL thing ASAP
而rpush命令可向list的右边(尾部)添加一个新元素。最后lrange 命令可从list中取出一定范围的元素;
集合类型:
Redis集合是未排序的集合,其元素是二进制安全的字符串。可以实现检测某个元素是否存在,以及实现交集,并集,差集等等
$ redis-cli sadd myset 1
(integer) 1
$ redis-cli sadd myset 2
(integer) 1
$ redis-cli sadd myset 3
(integer) 1
$ redis-cli smembers myset
1. 3
2. 1
3. 2
检测是否存在:

$ redis-cli sismember myset 3
(integer) 1
$ redis-cli sismember myset 30
(integer) 0
有序集合:
Redis1.2引入了有序集合,ZRANGE只属于有序集合;
对元素要想得到多种排序,一种可选方案是同时将每个元素加入多个有序集合。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  数据结构 redis