一、Redis的数据结构
Redis是一个Key-Value的数据库,key一般是String类型,不过Value的类型却有很多:
- String:
Hello World
- Hash:
{name: "jack", age: 21}
- List:
[A -> B -> C -> C]
- Set:
{A, B, C}
- SortedSet:
{A: 1, B: 2, C: 3}
- GEO:
{A: (120.3, 30.5)}
- BitMap:
0110110101110101011
- HyperLog:
0110110101110101011
由于Redis对数据类型是按组别进行数据操作,所以我们可以到官网的文档进行查询,也可以通过命令行进行查询。
#查询string的操作符
help @string
二、Redis基本数据类型
(一)、String类型
String类型,也就是字符串类型,是Redis中最简单的存储类型。
其Value是字符串,根据字符串的格式不同,又可以分成 3 类:
- string: 字符串,最大操作空间为512mb
- int: 整数类型,可以做自增、自减操作
- float: 浮点类型,可以做自增、自减操作
查看操作文档
help @string
1、SET: 添加或者修改已经存在的Stirng类型键值对
(1)帮助文档描述
SET key value [EX seconds|PX milliseconds|EXAT timestamp|PXAT milliseconds-timestamp|KEEPTTL] [NX|XX] [GET]summary: Set the string value of a keysince: 1.0.0group: string
(2)使用命令
#设置 key-value 键值对
SET k1 1
2、GET: 根据key获取String类型的value
(1)帮助文档描述
GET keysummary: Get the value of a keysince: 1.0.0group: string
(2)使用命令
#获取 k1 的值,获取到 "1"
GET k1
3、MSET: 批量添加键值对
(1)帮助文档描述
MSET key value [key value ...]summary: Set multiple keys to multiple valuessince: 1.0.1group: string
(2)使用命令
#批量插入键值对
MSET k2 2 k3 3 k4 4
4、MGET: 批量根据key获取值
(1)帮助文档描述
MGET key [key ...]summary: Get the values of all the given keyssince: 1.0.0group: string
(2)使用命令
#批量根据key获取值,查询到的值: "1" "2" "3" "4" (nil) (nil),当我们查询一个没有的key,它的值为 nil,就是null的意思
MGET k1 k2 k3 k4 k5 k6
5、INCR: 让一个整型的key自增1
(1)帮助文档描述
INCR keysummary: Increment the integer value of a key by onesince: 1.0.0group: string
(2)使用命令
# 使一个key自增,返回自增后的数值:(integer) 2
INCR k1
6、INCRBY: 让一个整型的key自增并指定步长
(1)帮助文档描述
INCRBY key incrementsummary: Increment the integer value of a key by the given amountsince: 1.0.0group: string
(2)使用命令
# 使一个key自增指定步长,返回自增后的数值:(integer) 4
INCRBY k1 2
7、INCRBYFLOAT: 让一个浮点类型的key自增并指定步长
(1)帮助文档描述
INCRBYFLOAT key incrementsummary: Increment the float value of a key by the given amountsince: 2.6.0group: string
(2)使用命令
# 使一个key自增指定步长,k5=12.1,返回自增后的数值: "12.6"
INCRBYFLOAT k5 0.5
8、SETNX: 添加一个String类型的键值对,前提是这个key不存在,否则不执行
(1)帮助文档描述
SETNX key valuesummary: Set the value of a key, only if the key does not existsince: 1.0.0group: string
(2)使用命令
# 添加一个String键值对,取出来是"\xe8\xbf\x99\xe6\x98\xafkey6"
SETNX k6 这是key6
9、SETEX: 添加一个String类型的键值对,并且指定有效期
(1)帮助文档描述
SETEX key seconds valuesummary: Set the value and expiration of a keysince: 2.0.0group: string
(2)使用命令
# 添加一个指定时长的键值对,就是 SET k7 Jhon + EXPIRE k7 3000,命令执行
SETEX k7 3000 Jhon
思考: Redis没有MySQL中的Table的概念,如何区分不同类型的key。
例如:需要存储用户、商品信息到redis,由一个用户id是1,有个商品id也是1
key的结构
Redis的key允许有个多单词形成层级结构,多个单词之间用 “:” 隔开,格式如下:项目名:业务名:类型:id
(二)、Hash类型
Hash类型,页脚散列,其value是一个无序字典,类似HashMap结构
Hash结构的Value被分成了 field 和 value 字段,即一个 key 对应的是多个键值对。
查看操作文档
help @hash
1、HSET key field value: 添加或修改hash-key 的 field 值
(1)帮助文档描述
HSET key field value [field value ...]summary: Set the string value of a hash fieldsince: 2.0.0group: hash
(2)使用命令
HSET zengoo:user:1 name zain age 23 gender 0
2、HGET key field: 获取一个hash-key的field值
(1)帮助文档描述
HGET key fieldsummary: Get the value of a hash fieldsince: 2.0.0group: hash
(2)使用命令
HGET zengoo:user:1 name
3、HMSET: 批量添加多个hash-key的field值
(1)帮助文档描述
HMSET key field value [field value ...]summary: Set multiple hash fields to multiple valuessince: 2.0.0group: hash
(2)使用命令
HMSET zengoo:product:1 name HWMate40 price 4599 tag phone size large
4、HMGET: 批量获取多个hash-key的field值
(1)帮助文档描述
HMGET key field [field ...]summary: Get the values of all the given hash fieldssince: 2.0.0group: hash
(2)使用命令
HMGET zengoo:product:1 name price tag size
5、HGETALL: 获取一个hash-key的所有键值对
(1)帮助文档描述
HGETALL keysummary: Get all the fields and values in a hashsince: 2.0.0group: hash
(2)使用命令
HGETALL zengoo:product:1
6、HKEYS: 获取一个hash-key的所有field
(1)帮助文档描述
HKEYS keysummary: Get all the fields in a hashsince: 2.0.0group: hash
(2)使用命令
HKEYS zengoo:product:1
7、HVALS: 获取一个hash-key的所有value
(1)帮助文档描述
HVALS keysummary: Get all the values in a hashsince: 2.0.0group: hash
(2)使用命令
HVALS zengoo:product:1
8、HINCRBY: 让一个hash-key字段自增长指定步长
(1)帮助文档描述
HINCRBY key field incrementsummary: Increment the integer value of a hash field by the given numbersince: 2.0.0group: hash
(2)使用命令
HINCRBY zengoo:product:1 price 1
9、HSETNX: 添加一个hash-key的field,若存在则不执行
(1)帮助文档描述
HSETNX key field valuesummary: Set the value of a hash field, only if the field does not existsince: 2.0.0group: hash
(2)使用命令
HSETNX zengoo:product:1 provider HW
(三)、List类型
Redis的List类型与Java中 LinkedList 类似,可以看做是一个双向链表结果,既可以正向检索,又支持反向检索。
特征(链表特征):
- 有序
- 元素可重复
- 插入和删除快
- 查询速度一般
查询帮助文档
help @list
1、LPUSH key element…:入栈
(1)帮助文档描述
LPUSH key element [element ...]summary: Prepend one or multiple elements to a listsince: 1.0.0group: list
(2)使用命令
LPUSH zengoo:praise:1 Zengoo Zain Jhon Anna Andy
2、LPOP key: 出栈,没有则返回nil
(1)帮助文档描述
LPOP key [count]summary: Remove and get the first elements in a listsince: 1.0.0group: list
(2)使用命令
# 出栈指定 key 的 n 个 value
LPOP zengoo:praise:1 2
3、RPUSH key element…: 向队列插入一个或多个元素
(1)帮助文档描述
RPUSH key element [element ...]summary: Append one or multiple elements to a listsince: 1.0.0group: list
(2)使用命令
# 入栈指定 key 的 n 个 value
RPUSH zengoo:praise:2 1 2 3
4、RPOP key: 队列出队
(1)帮助文档描述
RPOP key [count]summary: Remove and get the last elements in a listsince: 1.0.0group: list
(2)使用命令
RPOP zengoo:praise:1 6
5、LRANGE key star end: 返回一段范围的所有元素
(1)帮助文档描述
LRANGE key start stopsummary: Get a range of elements from a listsince: 1.0.0group: list
(2)使用命令
# 读取指定 key 的 0-9 索引的值
LRANGE zengoo:parise:1 0 9
6、BLPOP 和 BRPOP: 与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil
(1)帮助文档描述
#BLPOPBLPOP key [key ...] timeoutsummary: Remove and get the first element in a list, or block until one is availablesince: 2.0.0group: list#BRPOPBRPOP key [key ...] timeoutsummary: Remove and get the last element in a list, or block until one is availablesince: 2.0.0group: list
(2)使用命令
BLPOP zengoo:parise:1 10
为什么有左右侧的分别?
因为redis的list是链表形式的,可以从左右两侧挂载数据,可以认为是一个双向队列。
这里的BLPOP或者BRPOP中的B到底是什么意思?
这里的 B 是阻塞的意思,即等待一定的时间,要么过期,要么获取到值。
(四)、Set类型
Redis的Set结构与Java中的HashSet类似,可以看做一个value为null的hashSet,因为是一个hash表,因此具有与hashSet类似的特征:
- 无序
- 元素不重复
- 查找快
- 支持交并补差的操作
查询帮助文档
help @set
1、SADD key member…: 向set添加一个或多个元素
(1)帮助文档描述
SADD key member [member ...]summary: Add one or more members to a setsince: 1.0.0group: set
(2)使用命令
SADD zengoo:friends:1 Any Femon Lucy Karen Elean
2、SREM key member…: 删除set中的指定元素
(1)帮助文档描述
SREM key member [member ...]summary: Remove one or more members from a setsince: 1.0.0group: set
(2)使用命令
SREM zengoo:friends:1 Lucy
3、SCARD key: 返回set中元素的个数
(1)帮助文档描述
SCARD keysummary: Get the number of members in a setsince: 1.0.0group: set
(2)使用命令
SCARD zengoo:friends:1
4、SISMEMBER key member: 判断一个元素是否存在
(1)帮助文档描述
SISMEMBER key membersummary: Determine if a given value is a member of a setsince: 1.0.0group: set
(2)使用命令
SISMEMBER zengoo:friends Lucy
5、SMEMBERS: 获取set中的所有元素
(1)帮助文档描述
SMEMBERS keysummary: Get all the members in a setsince: 1.0.0group: set
(2)使用命令
SMEMBERS zengoo:friends:1
6、SINTER ke1 key2…: 求key1与key2的交集
(1)帮助文档描述
SINTER key [key ...]summary: Intersect multiple setssince: 1.0.0group: set
(2)使用命令
SINTER zengoo:friends:1 zengoo:friends:2
7、SDIF key1 key2…: 求key1与key2的差集
(1)帮助文档描述
SDIFF key [key ...]summary: Subtract multiple setssince: 1.0.0group: set
(2)使用命令
SDIFF zengoo:friends:1 zengoo:friends:2
8、SUNION key1 key2…: 求key1与key2的并集
(1)帮助文档描述
SUNION key [key ...]summary: Add multiple setssince: 1.0.0group: set
(2)使用命令
SUNION zengoo:friends:1 zengoo:friends:2
(五)、SortedSet类型
Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet类似,但底层的数据结构却差距很大。
SortedSet的每一个元素都带有score属性,可以给予score属性对元素进行排序,底层的视线是一个跳表(SkipList)+ Hash表。
查询文档:
help @sorted_set
特点:
- 可排序
- 元素不重复
- 查询速度快
1、ZADD key score member: 添加一个或多个元素到sorted set,如果存在则更新score
(1)帮助文档描述
ZADD key [NX|XX] [GT|LT] [CH] [INCR] score member [score member ...]summary: Add one or more members to a sorted set, or update its score if it already existssince: 1.2.0group: sorted_set
(2)使用命令
ZADD zengoo:basketball:zhejiang 1 yudu 2 kongjue 3 luosuan 4 alintuw 5 kuku
2、ZREM key member: 删除sorted set中的一个指定元素
(1)帮助文档描述
ZREM key member [member ...]summary: Remove one or more members from a sorted setsince: 1.2.0group: sorted_set
(2)使用命令
ZREM zengoo:basketball:xinjiang removeObject
3、ZSCORE key member: 获取sorted set中的指定元素的score
(1)帮助文档描述
ZSCORE key membersummary: Get the score associated with the given member in a sorted setsince: 1.2.0group: sorted_set
(2)使用命令
ZSCORE zengoo:basketball:zhejiang yudu
4、ZRANK key member: 获取sorted set中指定元素的排名
(1)帮助文档描述
ZRANK key membersummary: Determine the index of a member in a sorted setsince: 2.0.0group: sorted_set
(2)使用命令
ZRANK zengoo:basketball:zhejiang kuku
5、ZCARD key: 获取sorted set 中的元素个数
(1)帮助文档描述
ZCARD keysummary: Get the number of members in a sorted setsince: 1.2.0group: sorted_set
(2)使用命令
ZCARD zengoo:basketball:zhejiang
6、ZCOUNT key min max: 统计score值在指定范围内的所有元素的个数
(1)帮助文档描述
ZCOUNT key min maxsummary: Count the members in a sorted set with scores within the given valuessince: 2.0.0group: sorted_set
(2)使用命令
ZCOUNT zengoo:basketball:zhejiang 2 5
7、ZINCRBY key increment member: 让sorted set 中的指定元素自增,并自定义步长
(1)帮助文档描述
ZINCRBY key increment membersummary: Increment the score of a member in a sorted setsince: 1.2.0group: sorted_set
(2)使用命令
ZINCRBY zengoo:basketball:zhejiang 10 kuku
8、ZRANGE key min max: 按照score排序后,获取指定排名范围内的元素
(1)帮助文档描述
ZRANGE key min max [BYSCORE|BYLEX] [REV] [LIMIT offset count] [WITHSCORES]summary: Return a range of members in a sorted setsince: 1.2.0group: sorted_set
(2)使用命令
ZRANGE zengoo:basketball:zhejiang 1 16
9、ZRANGEBYSCORE key min max: 按照score排序后,获取指定score范围内的元素
(1)帮助文档描述
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]summary: Return a range of members in a sorted set, by scoresince: 1.0.5group: sorted_set
(2)使用命令
ZRANGEBYSCORE zengoo:basketball:zhejiang 0 100
10、ZDIFF、ZINTER、ZUNION: 求差集、交集、并集
(1)帮助文档描述
ZDIFF numkeys key [key ...] [WITHSCORES]summary: Subtract multiple sorted setssince: 6.2.0group: sorted_setZINTER numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]summary: Intersect multiple sorted setssince: 6.2.0group: sorted_setZUNION numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX] [WITHSCORES]summary: Add multiple sorted setssince: 6.2.0group: sorted_set
三、Redis特殊数据类型
(一)GEO类型: 地理信息
(二)BitMap类型
(三)HyperLog类型
四、Redis通用命令
通用命令是不分数据类型通用的操作命令
(一)查询generic文档
help @generic
(二)常用命令:
1、KEYS: 查看符合模板的所有key(因为Redis是单线程执行,所以不建议在生产环境使用)。
(1)帮助文档描述
KEYS pattern #命令格式summary: Find all keys matching the given pattern #命令作用since: 1.0.0 #起源版本group: generic #隶属组别
(2)使用命令
#查询当前数据库的所有key
KEYS *#查询以a结尾的所有key
KEYS a*
2、DEL: 删除指定的Key
(1)帮助文档描述
DEL key [key ...]summary: Delete a keysince: 1.0.0group: generic
(2)使用命令
#删除指定key(返回真实删除数)
DEL key1 key2
3、EXISTS: 查看是否存在指定key
(1)帮助文档描述
EXISTS key [key ...]summary: Determine if a key existssince: 1.0.0group: generic
(2)使用命令
#查询指定key是否存在(返回查询到的数量,若为0则不存在key,若有则存在key)
EXISTS k2
#我的数据库中只有k1 一个key,所以查询k2的结果是 (integer) 0#查询多个key是否存在,缺陷是无法判断哪个存在
EXISTS k1 k2
#查询到的结果是 (integer) 1
4、EXPIRE: 给key设置有效期,到期删除(一看到这个就能想到外卖的付款倒计时)
因为内存是临时的,所以需要有效期,所以才会有这个命令
(1)帮助文档描述
EXPIRE key secondssummary: Set a key's time to live in secondssince: 1.0.0group: generic
(2)使用命令
#给 key1 设置一个 5s 的时间,查看5s后是否还存在
EXPIRE k1 5
EXISTS k1//5s后,再次查询k1
EXISTS k1
5、TTL: 查看一个key的有效期
(1)帮助文档描述
TTL keysummary: Get the time to live for a keysince: 1.0.0group: generic
(2)使用命令
#查看一个未设置有效期的key,查询结果: (integer) -1,代表永久有效
TTL k2#查看一个设置有效期为5分钟的key,查询结果: (integer) 2996,若过期,则为-2
TTL k1