Redis基础学习
Redis是一种可基于内存、分布式,可选持久化的键值对存储数据库,提供了多种语言API。
其值value可以是字符串(String), 哈希(Hash),列表(list),集合(set)和有序集合等类型。
Redis的特点:
- Redis支持数据持久化,可将内存中的数据保存在磁盘中,重启的时候再加载使用
- Redis支持丰富的数据类型,例如简单的key-value, 还有list, set , zset, hash等数据结构
- Redis支持数据备份,即master-slave模式的数据备份
Redis的优势:
- 性能极高: Redis能读的速度是110000次/s , 写的速度是 81000次/s
- 丰富的数据类型:String,List,Hash,Set , Order Set
- 原子:Redis所有操作都是原子性的,即要么成功要失败。单个操作时原子性的,多个操作也支持事务,即原子性。用MULTI和EXEC
- 丰富的特性:Redis支持public/subscribe,通知,key过期等特性
redis-server :是redis服务器端
redis.conf 是redis服务器启动时,可以指定的配置文件
redis-cli 是redis客户端,可以用来与redis服务交互
使用redis-cli连接远程服务器:
redis-cli -h host -p port -a password
连接本地直接输入redis-cli即可。
检测redis是否启动:PING
Redis数据类型
Redis支持5中数据类型:string(字符串), hash(哈希), list(列表), set(集合) 及 zset(sorted set:有序集合)。
String
string类型是Redis最基本的数据类型,string类型最大能存储512MB
SET 和 GET
SET runoob "菜鸟教程"
GET runoob
键为 runoob,对应的值为 菜鸟教程
其他语法
1.SET key value : 设置指定 key 的值 2.GET key : 获取指定 key 的值。 3. GETRANGE key start end : 返回 key 中字符串值的子字符 4. GETSET key value : 将给定 key 的值设为 value ,并返回 key 的旧值(old value)。 5. GETBIT key offset : 对 key 所储存的字符串值,获取指定偏移量上的位(bit)。 6. MGET key1 [key2..] : 获取所有(一个或多个)给定 key 的值。 7. SETBIT key offset value : 对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)。 8. SETEX key seconds value : 将值 value 关联到 key ,并将 key 的过期时间设为 seconds (以秒为单位)。 9. SETNX key value : 只有在 key 不存在时设置 key 的值。 10. SETRANGE key offset value : 用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始。 11. STRLEN key : 返回 key 所储存的字符串值的长度。 12. MSET key value [key value ...] : 同时设置一个或多个 key-value 对。 13. MSETNX key value [key value ...] : 同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。 14. PSETEX key milliseconds value : 这个命令和 SETEX 命令相似,但它以毫秒为单位设置 key 的生存时间,而不是像 SETEX 命令那样,以秒为单位。 15. INCR key : 将 key 中储存的数字值增一。 16. INCRBY key increment : 将 key 所储存的值加上给定的增量值(increment) 。 17. INCRBYFLOAT key increment : 将 key 所储存的值加上给定的浮点增量值(increment) 。 18. DECR key : 将 key 中储存的数字值减一。 19. DECRBY key decrement : key 所储存的值减去给定的减量值(decrement) 。 20. APPEND key value : 如果 key 已经存在并且是一个字符串, APPEND 命令将指定的 value 追加到该 key 原来值(value)的末尾
Hash
HMSET 和 HGET
删除之前用过的key
DEL runoob
使用HMSET设置field-value对
HMSET runoob field1 "Hello" field2 "World"
使用HGET获取对应field对应的value
HGET runoob field1
结果:
"Hello"
1 HDEL key field1 [field2]
删除一个或多个哈希表字段
2 HEXISTS key field
查看哈希表 key 中,指定的字段是否存在。
3 HGET key field
获取存储在哈希表中指定字段的值。
4 HGETALL key
获取在哈希表中指定 key 的所有字段和值
例如:
> hmset swy1 name "vin" description "hello" age 12
> hgetall swy1
1) "name"
2) "vin"
3) "description"
4) "hello"
5) "age"
6) "12"
5 HINCRBY key field increment
为哈希表 key 中的指定字段的整数值加上增量 increment 。
6 HINCRBYFLOAT key field increment
为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
7 HKEYS key
获取所有哈希表中的字段
8 HLEN key
获取哈希表中字段的数量
9 HMGET key field1 [field2]
获取所有给定字段的值
10 HMSET key field1 value1 [field2 value2 ]
同时将多个 field-value (域-值)对设置到哈希表 key 中。
11 HSET key field value
将哈希表 key 中的字段 field 的值设为 value 。
12 HSETNX key field value
只有在字段 field 不存在时,设置哈希表字段的值。
13 HVALS key
获取哈希表中所有值。
14 HSCAN key cursor [MATCH pattern] [COUNT count]
迭代哈希表中的键值对。
List
lpush 和 lrange
插入列表(按插入顺序排序)
lpush runooblist redis
lpush runooblist mongodb
获取列表
lrange runoob 0 10
结果:
1) "mongodb"
2) "redis"
1 BLPOP key1 [key2 ] timeout
移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
2 BRPOP key1 [key2 ] timeout
移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
3 BRPOPLPUSH source destination timeout
从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
4 LINDEX key index
通过索引获取列表中的元素
5 LINSERT key BEFORE|AFTER pivot value
在列表的元素前或者后插入元素
LINSERT mylist BEFORE "World" "There"
6 LLEN key
获取列表长度
7 LPOP key
移出并获取列表的第一个元素
8 LPUSH key value1 [value2]
将一个或多个值插入到列表头部
9 LPUSHX key value
将一个值插入到已存在的列表头部
10 LRANGE key start stop
获取列表指定范围内的元素
11 LREM key count value
移除列表元素
COUNT 的值可以是以下几种:
- count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。
- count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。
- count = 0 : 移除表中所有与 VALUE 相等的值。
12 LSET key index value
通过索引设置列表元素的值
13 LTRIM key start stop
对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
14 RPOP key
移除列表的最后一个元素,返回值为移除的元素。
15 RPOPLPUSH source destination
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
16 RPUSH key value1 [value2]
在列表中添加一个或多个值
17 RPUSHX key value
为已存在的列表添加值
Set
sadd 和 smembers
添加元素到set集合
sadd key member
查看集合元素
smembers runoob
1 SADD key member1 [member2]
向集合添加一个或多个成员
2 SCARD key
获取集合的成员数量
3 SDIFF key1 [key2]
返回第一个集合与其他集合之间的差异。
4 SDIFFSTORE destination key1 [key2]
返回给定所有集合的差集并存储在 destination 中
5 SINTER key1 [key2]
返回给定所有集合的交集
6 SINTERSTORE destination key1 [key2]
返回给定所有集合的交集并存储在 destination 中
7 SISMEMBER key member
判断 member 元素是否是集合 key 的成员
8 SMEMBERS key
返回集合中的所有成员
9 SMOVE source destination member
将 member 元素从 source 集合移动到 destination 集合
10 SPOP key
移除并返回集合中的一个随机元素
11 SRANDMEMBER key [count]
返回集合中一个或多个随机数
12 SREM key member1 [member2]
移除集合中一个或多个成员
13 SUNION key1 [key2]
返回所有给定集合的并集
14 SUNIONSTORE destination key1 [key2]
所有给定集合的并集存储在 destination 集合中
15 SSCAN key cursor [MATCH pattern] [COUNT count]
迭代集合中的元素
SSCAN myset1 0 match R*
zset(有序集合)
每个元素都会关联一个double类型的分数,redis是通过分数为集合中的成员从小到大排序的。
zset成员是唯一的,但分数可以重复。
zadd 和 zrangebyscore
添加元素到有序集合
zadd key score member
zadd runoob 0 redis
zadd runoob 0 mongodb
zadd runoob 0 rabbitmq
展示集合元素
ZRANGEBYSCORE runoob 0 1000
结果:
1) "mongodb"
2) "rabbitmq"
3) "redis"
1 ZADD key score1 member1 [score2 member2]
向有序集合添加一个或多个成员,或者更新已存在成员的分数
2 ZCARD key
获取有序集合的成员数
3 ZCOUNT key min max
计算在有序集合中指定区间分数的成员数
4 ZINCRBY key increment member
有序集合中对指定成员的分数加上增量 increment
redis> ZADD myzset 1 "one"
(integer) 1
redis> ZADD myzset 2 "two"
(integer) 1
redis> ZINCRBY myzset 2 "one"
"3"
5 ZINTERSTORE destination numkeys key [key ...]
计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 destination 中
其中给定 key 的数量必须以 numkeys 参数指定
6 ZLEXCOUNT key min max
在有序集合中计算指定字典区间内成员数量
7 ZRANGE key start stop [WITHSCORES]
通过索引区间返回有序集合指定区间内的成员
其中成员的位置按分数值递增(从小到大)来排序。
具有相同分数值的成员按字典序(lexicographical order )来排列。
8 ZRANGEBYLEX key min max [LIMIT offset count]
通过字典区间返回有序集合的成员
redis 127.0.0.1:6379> ZADD myzset 0 a 0 b 0 c 0 d 0 e 0 f 0 g
(integer) 7
redis 127.0.0.1:6379> ZRANGEBYLEX myzset - [c
1) "a"
2) "b"
3) "c"
redis 127.0.0.1:6379> ZRANGEBYLEX myzset - (c
1) "a"
2) "b"
redis 127.0.0.1:6379> ZRANGEBYLEX myzset [aaa (g
1) "b"
2) "c"
3) "d"
4) "e"
5) "f"
9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]
通过分数返回有序集合指定区间内的成员
10 ZRANK key member
返回有序集合中指定成员的索引
11 ZREM key member [member ...]
移除有序集合中的一个或多个成员
12 ZREMRANGEBYLEX key min max
移除有序集合中给定的字典区间的所有成员
13 ZREMRANGEBYRANK key start stop
移除有序集合中给定的排名区间的所有成员
14 ZREMRANGEBYSCORE key min max
移除有序集合中给定的分数区间的所有成员
15 ZREVRANGE key start stop [WITHSCORES]
返回有序集中指定区间内的成员,通过索引,分数从高到低
其中成员的位置按分数值递减(从大到小)来排列。
具有相同分数值的成员按字典序的逆序(reverse lexicographical order)排列。
除了成员按分数值递减的次序排列这一点外, ZREVRANGE 命令的其他方面和 ZRANGE 命令一样。
16 ZREVRANGEBYSCORE key max min [WITHSCORES]
返回有序集中指定分数区间内的成员,分数从高到低排序
有序集成员按分数值递减(从大到小)的次序排列。
具有相同分数值的成员按字典序的逆序(reverse lexicographical order )排列。
除了成员按分数值递减的次序排列这一点外, ZREVRANGEBYSCORE 命令的其他方面和 ZRANGEBYSCORE 命令一样。
17 ZREVRANK key member
返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
18 ZSCORE key member
返回有序集中,成员的分数值
19 ZUNIONSTORE destination numkeys key [key ...]
计算给定的一个或多个有序集的并集,并存储在新的 key 中
20 ZSCAN key cursor [MATCH pattern] [COUNT count]
迭代有序集合中的元素(包括元素成员和元素分值)
Redis键(key)
1. DEL key : 删除key
2. DUMP key : 序列化key
3. EXISTS key : 检查key是否存在
4. EXPIRE key seconds : 给key设置过期时间,单位秒
5. EXPIREAT key timestamp : 为key设置过期时间,但是接受的时间为 unix 时间戳(unix timestamp).
6. PEXPIRE key milliseconds : 设置过期时间,以毫秒计
7. PEXPIREAT key milliseconds-timestamp : 设置过期时间,unix时间戳,毫秒
8. KEYS pattern : 查找所有符合给定模式的key
9. MOVE key db : 将当前数据库的key移动到给定数据库的db中
10. PERSIST key : 移除key的过期时间,key将持久保持
11. PTTL key : 以毫秒为单位返回 key 的剩余的过期时间。
12. TTL key : 以秒为单位,返回给定 key 的剩余生存时间(TTL, time to live)。
13. RANDOMKEY : 从当前数据库中随机返回一个 key 。
14. RENAME key newkey : 修改 key 的名称
15. RENAMENX key newkey : 仅当 newkey 不存在时,将 key 改名为 newkey
16. SCAN cursor [MATCH pattern] [COUNT count] : 迭代数据库中的数据库键。命令解释:scan 游标 MATCH <返回和给定模式相匹配的元素> count 每次迭代所返回的元素数量 。示例:scan 0 match DL* count 5
17.TYPE key : 返回 key 所储存的值的类型。