1 hashes 类型及操作
redis hash 是一个string 类型的 field 和 value 的映射表。他的添加、删除操作时间复杂度都是 O(1)
2 hset,设置 hash field 为指定值,如果 key 不存在,则先创建。
redis 127.0.0.1:> hset myhash field1 Hello
(integer)
3 hsetnx,设置 hash field 为指定值,如果 key 不存在,则先创建。如果 field 已经存在,返回 0,nx 是not exist 的意思。
redis 127.0.0.1:> hsetnx myhash field "Hello"
(integer)
4 hmset,同时设置 hash 的多个 field。
redis 127.0.0.1:> hmset myhash field1 Hello field2 World
OK
5 hget,获取指定的 hash field。
redis 127.0.0.1:> hget myhash field1
"Hello"
6 hmget,获取全部指定的 hash filed。
redis 127.0.0.1:> hmget myhash field1 field2 field3
) "Hello"
) "World"
) (nil)
7 hincrby,指定的 hash filed 加上给定值。
redis 127.0.0.1:> hset myhash field3
(integer)
redis 127.0.0.1:> hget myhash field3
""
redis 127.0.0.1:> hincrby myhash field3 -
(integer)
redis 127.0.0.1:> hget myhash field3
""
8 hexists,测试指定 field 是否存在。
redis 127.0.0.1:> hexists myhash field1
(integer)
9 hlen,返回指定 hash 的 field 数量。
redis 127.0.0.1:> hlen myhash
(integer)
10 hdel,删除指定 field,并返回指定 hash 的 field 数量。
redis 127.0.0.1:> hlen myhash
(integer)
redis 127.0.0.1:> hdel myhash field1
(integer)
redis 127.0.0.1:> hlen myhash
(integer)
11 hkeys,返回 hash 的所有 field。
redis 127.0.0.1:> hkeys myhash
) "field2"
) "field"
) "field3"
12 hvals,返回 hash 的所有 value。
redis 127.0.0.1:> hvals myhash
) "World"
) "Hello"
) ""
13 hgetall,获取某个 hash 中全部的 filed 及 value。
14 lists,Redis 的 list 类型其实就是一个每个子元素都是 string 类型的双向链表。链表的最大长度是(2的 32 次方)。我们可以通过 push,pop 操作从链表的头部或者尾部添加删除元素。这使得 list
既可以用作栈,也可以用作队列。
lpush,在 key 对应 list 的头部添加字符串元素
rpush,在 key 对应 list 的尾部添加字符串元素
linsert,在 key 对应 list 的特定位置之前或之后添加字符串元素,
redis 127.0.0.1:> rpush mylist3 "hello"
(integer)
redis 127.0.0.1:> rpush mylist3 "world"
(integer)
redis 127.0.0.1:> linsert mylist3 before "world" "there"
(integer)
lset,设置 list 中指定下标的元素值(下标从 0 开始)
lrem,从 key 对应 list 中删除 count 个和 value 相同的元素。count>0 时,按从头到尾的顺序删除。count=0 时,删除全部。
ltrim,保留指定 key 的值范围内的数据。
redis 127.0.0.1:> rpush mylist8 "one"
(integer)
redis 127.0.0.1:> rpush mylist8 "two"
(integer)
redis 127.0.0.1:> rpush mylist8 "three"
(integer)
redis 127.0.0.1:> rpush mylist8 "four"
(integer)
redis 127.0.0.1:> ltrim mylist8 -
OK
redis 127.0.0.1:> lrange mylist8 -
) "two"
) "three"
) "four"
lpop,从 list 的头部删除元素,并返回删除元素。
rpop,从 list 的尾部删除元素,并返回删除元素。
redis 127.0.0.1:> lrange mylist -
) "hello"
) "world"
redis 127.0.0.1:> lpop mylist
"hello"
redis 127.0.0.1:> lrange mylist -
) "world"
rpoplpush,
从第一个 list 的尾部移除元素并添加到第二个 list 的头部,最后返回被移除的元素值,整个操作是原子的.如果第一个 list 是空或者不存在返回 nil。
redis 127.0.0.1:> lrange mylist5 -
) "three"
) "foo"
) "hello"
redis 127.0.0.1:> lrange mylist6 -
) "hello"
) "foo"
redis 127.0.0.1:> rpoplpush mylist5 mylist6
"hello"
redis 127.0.0.1:> lrange mylist5 -
) "three"
) "foo"
redis 127.0.0.1:> lrange mylist6 -
) "hello"
) "hello"
) "foo"
lindex,返回名称为 key 的 list 中 index 位置的元素
redis 127.0.0.1:> lrange mylist5 -
) "three"
) "foo"
redis 127.0.0.1:> lindex mylist5
"three"
llen,返回 key 对应 list 的长度
redis 127.0.0.1:> llen mylist5
(integer)
15 set
set 是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中 key 理解为集合的名字。
Redis 的 set 是 string 类型的无序集合。set 元素最大可以包含(2 的 32 次方)个元素。
set 的是通过 hash table 实现的,所以添加、删除和查找的复杂度都是 O(1)。
sadd,向名称为 key 的 set 中添加元素
srem,删除名称为 key 的 set 中的元素 member
redis 127.0.0.1:> sadd myset2 "one"
(integer)
redis 127.0.0.1:> sadd myset2 "two"
(integer)
redis 127.0.0.1:> sadd myset2 "three"
(integer)
redis 127.0.0.1:> srem myset2 "one"
(integer)
redis 127.0.0.1:> srem myset2 "four"
(integer)
redis 127.0.0.1:> smembers myset2
) "three"
) "two"
spop,随机返回并删除名称为 key 的 set 中一个元素
sdiff,返回所有给定 key 与第一个 key 的差集
sdiffstore,返回所有给定 key 与第一个 key 的差集,并将结果存为另一个 key
redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> sdiffstore myset4 myset2 myset3
(integer)
redis 127.0.0.1:> smembers myset4
) "three"
sinter,返回所有给定 key 的交集
redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> sinter myset2 myset3
) "two"
sinterstore,返回所有给定 key 的交集,并将结果存为另一个 key
sunion,返回所有给定 key 的并集
sunionstore,返回所有给定 key 的并集,并将结果存为另一个 key
smove,从第一个 key 对应的 set 中移除 member 并添加到第二个对应 set 中
redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> smove myset2 myset7 three
(integer)
redis 127.0.0.1:> smembers myset7
) "three"
scard,返回名称为 key 的 set 的元素个数
sismember,测试 member 是否是名称为 key 的 set 的元素。
redis 127.0.0.1:> smembers myset2
) "two"
redis 127.0.0.1:> sismember myset2 two
(integer)
redis 127.0.0.1:> sismember myset2 one
(integer)