Redis是一款是以键值对为存储结构的高性能的内存非关系型数据库,主要特点为:
- 非关系型数据库,数据之间没有必然的关系
- 内部采用单线程工作
- 高性能,每秒支持十几万次读写操作
- 支持的数据类型包括:字符串(String)、散列(Hash)、列表(List)、集合(Set)、有序集合(Sorted_set)
各类型的基本操作
1、字符串(String)
- 添加/修改数据
set key value
- 获取数据,若为空,则返回nil
get key
- 删除数据,返回1代表成功,0代表失败
del key
- 添加多个数据
mset key1 value1 key2 value2
- 查询多个数据
mget key1 key2
- 获取key对应的value的长度
strlen key1
- 追加信息到原始value之后
append key1 appendValue
说明,多指令操作,看起来就单操作指令的简单相加,其实不然,指令耗时可以在三个地方:发送指令、处理指令、返回指令,多操作指令相对于多次单操作指令,大大减少上面说的三个方面的耗时。
- 设置数值的增加
incr key
incrby key increment
incrbyfloat key increment
- 设置数值减少
decr key
decrby key increment
- 设置数据的生命周期(用于秒杀等有时间限制的场景)
#秒
setex key seconds value
#毫秒
psetex key milliseconds value
2、散列(Hash)
主要用于在一个存储空间内保存多个键值对信息。
- 添加/修改数据
hset key field value
- 获取数据
#获取key下一个键值
hget key field
#获取key下所有键值
hgetall key
- 删除数据
hdel key field
- 添加/修改多个数据
注:貌似hset也可以啊,区别在哪里?
hmset key field1 value1 field2 value2
- 获取多个数据
hmget key field1 field2
- 获取hash表中字端数量
hlen key
- 获取hash表中是否存在指定字段,1表示存在,0表示不存在
hexists key field
- 获取hash表中所有字段名/字段值
#所有字段名
hkeys key
#所有字段值
hvals key
- 设置字段数值增加
hincrby key field increment
hincrbyfloat key field increment
3、列表(List)
list用于保存多个数据,并记录数据进入存储空间的顺序,底层实现为双向链表,所以可以从两头进行数据的操作。
- 添加/修改数据
#从左边插入
lpush key value1 value2
#从右边插入
rpush key value1 value2
- 获取数据
#从左到右按顺序查询
lrange key start stop (stop = -1时,表示最后一个元素)
lindex key index
llen key
- 获取并删除数据
#左边移除
lpop key
#右边移除
rpop key
- 规定时间内获取并移除数据
blpop key1 key2 timeout
brpop key1 key2 timeout
这条命令的意思是当列表中没有元素时,会等待timeout指定的时间,期间一旦有数据加入到List列表中,就会显示出来,否则时间到了后就显示为空。
- 移除指定数据
#从左边开始搜索,移除count个value
lrem key count value
3.4 集合(Set)
set与hash结构完全相同,不同在于set仅存储键key,不存储值value,并且值不允许为空。
set可以存储大量数据,在查询方面有较高的效率。
- 添加数据
sadd key member1 member2...
- 获取全部数据
smembers key
- 删除数据
srem key member1 member2 ...
- 获取集合数据总量
scard key
- 判断集合是否包含指定数据
sismember key member
- 随机获取集合中指定数量的数据
srandmember key [count]
- 随机获取集合中某个数据并移出集合
spop key
- 求两个集合的交/并/差集
sinter key1 key2 ..
sunion key1 key2 ..
sdiff key1 key2 ..
- 求两个集合的交/并/差集并存储到指定集合
sinterstore destination key1 key2 ..
sunionstore destination key1 key2 ..
sdiffstore destination key1 key2 ..
- 将数据从原始集合移动到目的集合
smove source destination member
4、有序集合(Sorted_set)
在集合(Set)增加了可排序字段,使得存储值可以按可排序字段来排序,可排序字段称为scope。
- 添加数据
zadd key score1 member1 score2 member2 ...
- 获取全部数据
zrange key start stop [withscores]
zrevrange key start stop [withscores]
- 删除数据
zrem key member1 member2...
- 按条件获取数据(limit用来限制查询结果的数量)
zrangebyscore key min max [withscores] [limit]
zrevrangebyscore key max min [withscores]
- 条件删除数据
zremrangebyrank key start stop
zremrangebyscore key min max
- 获取集合数据总量
zcard key
zcount key min max
- 集合并交操作
zinterstore destination numkeys key1 key2...(求交集,默认求出score的和,可以修改为最大值最小值等等)
zunionstore destination numkeys key1 key2...
5、redis数据库的操作
当key值过多时,总会出现key重复的问题,因此redis为每个服务提供了16个数据相互独立的数据库,可以相互切换。
- 切换数据库
select index(0-15)
- 数据移动,把一个数据剪切到另一个数据库
move key db