Redis
1.初识Redis
NoSQL 非关系型数据库
key-value 键值对数据库
Document以json数据存储
SQL | NoSQL | |
---|---|---|
数据结构 | 结构化(Structured) | 非结构化 |
数据关联 | 关联的(Relational) | 无关联 |
查询方式 | SQL查询 | 非SQL |
事务特性 | ACID | BASE |
存储方式 | 磁盘 | 内存 |
扩展性 | 垂直 | 水平 |
2.Redis常用命令
- 常见数据结构
Redis是一个key-value的数据库,key一般是String类型,不过value的类型多种多样
数据结构 | 存储类型 |
---|---|
string | hello world |
Hash | {name: “jack”,age: 20} |
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 |
- 常用通用命令
keys: 查看符合模板的所有key ,不建议在生产环境设备上使用
del :删除指定的key
exists:判断key是否存在
expire:给一个key设置有效期,有效期到期时该key会自动删除
ttl:查看一个key的剩余有效期 -2 到期 -1 永久有效 - 5种常用数据结构
string类型
string类型,也就是字符串类型,是Redis中最简单的存储类型
其value是字符串,不过根据字符串的格式不同,又可以分为3类:
string:普通字符串
int:整数类型,可以做自增,自减操作
float:浮点类型,可以做自增,自减操作
不管是哪种格式,底层都是字节数组形式存储,只不过是编码不同。字符串的最大空间不能超过521m。
string的常见命令:
set:添加或者修改已经存在的一个string类型的键值对
get:根据key获取string类型的value
mset:批量添加多个string类型的键值对
mget:根据多个key获取string类型的value
incr:让一个整型的key自增1
incrby:让一个整型的key自增并指定步长,例如incrby num 2
incrbyfloat:让一个浮点类型的数字自增并指定步长。
setnx:添加一个string类型的键值对,前提是这个key不存在,否则不执行
setex:添加一个string类型的键值对,并且指定有效期
Hash类型
Hash类型,也叫散列,其value是一个无无序字典,类似于java中的HashMap结构
Hash的常见命令
hset key field value :添加或者修改hash类型key的field值
hget key field:获取一个hash类型key的field的值
hmset:批量添加多个hash类型key的field的值
hmget: 批量获取多个hash类型key的field的值
hgetall:获取一个hash类型的key中的所有的field和value
hkeys:获取一个hash类型的key中的所有的field
hvals:获取一个hash类型的key中的所有value
hincrby:让一个hash类型key的字段值自增并指定步长
hsetnx:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行
List类型
Redis中的List类型与Java中的LinkedList类似,可以看做是一个双向链表结构。既可以支持正向检索和也可以支持反向检索。
List类型常用的命令有:
lpush key element...:向列表左侧插入一个或多个元素
lpop key:移除并返回列表左侧的第一个元素,没有则返回nil
rpush key element...:向列表右侧的第一个元素
rpop key :移除并返回列表右侧的第一个元素
lrange key star end :返回一段角标范围内的所有元素
blpop和brpop:与lpop和rpop类似,只不过在没有元素时等待指定时间,而不是直接返回nil
如何利用List结构模拟一个栈?
入口和出口在同一边
先进后出
如何利用List结构模拟一个队列?
入口和出口在不同边
先进先出
如何利用List结构模拟一个阻塞队列?
入口和出口在不同边
出队时采用blpop或brpop
Set类型
Redis的Set结构与Java中的HashSet类似,可以看做是一个value为null的HashMap。因为也是一个hash表,因此具备与HashSet类似的特征
Set类型的常见命令有:
sadd key member ...: 向set中添加一个或多个元素
srem key member...:移除set中的指定元素
scard key:返回set中元素的个数
sismember key member:判断一个元素是否存在于set中
smembers:获取set中的所有元素
sinter key1 key2 ... :求key1与key2的交集
sdiff key1 key2 ..:求key1与key2的差集
sunion key1 key2 .. :求key1和key2的并集
SortedSet类型
Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet有些类似,但底层数据结构却差别很大。SortedSet中的每一个元素都带有一个score属性,可用基于score属性对元素排序,底层的实现是一个跳表(SkipList)hash表。
SortedSet的常见命令有:
zadd key score member:添加一个或多个元素到sorted set,如果已经存在则更新其score值
zrem key member:删除sorted set中的一个指定元素
zscore key member:获取sorted set中的指定元素的score值
zrank key member:获取sorted set中的指定元素的排名
zcard key :获取sorted set中的元素个数
zcount key min max:统计score值在给定范围内的所有元素的个数
zincrby key increment member:让sorted set中的指定元素自增,步长为指定的increment值
zrange key min max :按照score排序后,获取指定排名范围内的元素
zrangebyscore key min max:按照score排序后,获取指定score范围内的元素
zdiff、zinter、zunion:求差集、交集、并集
注意:所有的排名默认都是升序,如果要降序则在命令的Z后面添加REV即可