目录
什么是Redis
概念
Redis (REmote DIctionary Server) 是用 C 语言开发的一个开源的高性能键值对(key-value)数据库,对数据的读写操作都是在内存中完成,因此读写速度非常快,常用于缓存、消息队列、分布式锁等场景。
特征
- 数据间没有必然的关联关系
- 内部采用单线程机制进行工作
- 高性能,官方提供测试数据,50个并发执行100000 个请求,读的速度是110000 次/s,写的速度是81000次/s。
- 多数据类型支持
字符串类型 | string |
---|---|
列表类型 | list |
散列类型 | hash |
集合类型 | set |
有序集合类型 | sorted_set |
- 持久化支持。可以进行数据灾难恢复
Redis基本操作
命令模式工具使用
- 功能性命令
- 清除屏幕信息
- 帮助信息查阅
- 退出指令
信息添加
- 功能:设置key,value数据
- 命令:set key value
信息查询
- 功能:根据key查询对应的value,如果不存在,返回空(null)
- 命令:get key
清除屏幕信息
- 功能:清除屏幕中的信息
- 命令:clear
退出客户端命令行模式
- 功能:退出客户端
- 命令:quit exit 按钮
帮助
- 功能:获取命令帮助文档,获取组中所有命令信息名称
- 命令:help 命令名称
help @组名
Redis数据类型(常用)
string | String |
---|---|
hash | HashMap |
list | LinkedList |
set | HashSet |
sorted_set | TreeSet |
redis数据存储格式
- redis自身是一个 Map,其中所有的数据都是采用 key : value 的形式存储
- 数据类型指的是存储的数据的类型,也就是 value 部分的类型,key 部分永远都是字符串
key的语法: - 在一个项目中,key最好使用统一的命名模式
- key区分大小写
- key不要太长,尽量不要超过1024字节。不仅消耗内存,也会降低查找的效率
- key不要太短,太短可读性会降低
String
- 存储的数据:单个数据,最简单的数据存储类型,也是最常用的数据存储类型
- 存储数据的格式:一个存储空间保存一个数据
- 存储内容:通常使用字符串,如果字符串以整数的形式展示,可以作为数字操作使用
常用命令
- 添加/修改数据
set key value
- 获取数据
get key
- 删除数据
del key
- 添加/修改多个数据
mset key1 value1 key2 value2 ... (m代表Multiple)
- 获取多个数据
mget key1 key2 ...
- 获取数据字符个数(字符串长度)
strlen key
- 追加信息到原始信息后部(如果原始信息存在就追加,否则新建)
append key value
- 按照范围获取
GETRANGE key 开始下标 结束下标
- 替换
SETRANGE key 位置
- 先get然后在set
getset key value
hash
- 存储的缺点
对象类数据的存储如果具有较频繁的更新需求操作会显得笨重 - hash哈希特点
- 新的存储需求:对一系列存储的数据进行编组,方便管理,典型应用存储对象
- 需要的存储结构:一个存储空间保存多个键值对数据
- hash类型:底层使用哈希表结构实现数据存储
- hash存储结构优化
- 如果field数量较少,存储结构优化为类数组结构
- 如果field数量较多,存储结构使用HashMap结构
常用命令
- 添加/修改数据
hset key field value
- 添加,但是有则不添加,无则添加
hsetnx key field value
- 获取数据
hget key field
hgetall key
- 删除数据
hdel key field1 [field2]
- 添加/修改多个数据
hmset key field1 value1 field2 value2 ...
- 获取多个数据
hmget key field1 field2 ...
- 获取哈希表中字段的数量
hlen key
- 获取哈希表中是否存在指定的字段
hexists key field
- 获取哈希表中所有的字段名或字段值
hkeys key
hvals key
- 设置指定字段的数值数据增加指定范围的值
hincrby key field increment
hincrbyfloat key field increment
hash 类型数据操作的注意事项
- hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。如果数据未获取到,对应的值为(null)
- 每个 hash 可以存储 2^3 2^-1个键值对
- hash类型十分贴近对象的数据存储形式,并且可以灵活添加删除对象属性。但hash设计初衷不是为了存储大量对象而设计的,切记不可滥用,更不可以将hash作为对象列表使用
- hgetall 操作可以获取全部属性,如果内部field过多,遍历整体数据效率就很会低,有可能成为数据访问瓶颈
List
- 数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
- 需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序
- list类型:保存多个数据,底层使用双向链表存储结构实现
常用命令
- 添加/修改数据
lpush key value1 [value2] ...
rpush key value1 [value2] ...
- 获取数据
lrange key start stop
lindex key index
llen key
- 获取并移除数据
lpop key
rpop key
- 通过下标截取指定的长度,这个list已经被改变了,只剩下截取的元素
ltrim key start end
- lset将列表中指定下标的值替换为另外一个值,更新操作
lset key 下标 新数据 //如果不存在列表我们去更新就会报错
- 将某个具体的value插入到列中的某个元素的前面或者后面
LINSERT mylist before "world" "other"
LINSERT mylist after "world" "other"
- 规定时间内获取并移除数据
b代表block阻塞
blpop key1 [key2] timeout
brpop key1 [key2] timeout
Set
- 新的存储需求:存储大量的数据,在查询方面提供更高的效率
- 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询
- set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的
常用命令
- 添加数据
sadd key member1 [member2]
- 获取全部数据
smembers key
- 获取集合数据总量
scard key
- 判断集合中是否包含指定数据
sismember key member
sorted_set
- 新的存储需求:数据排序有利于数据的有效展示,需要提供一种可以根据自身特征进行排序的方式
- 需要的存储结构:新的存储模型,可以保存可排序的数据
- sorted_set类型:在set的存储结构基础上添加可排序字段
常用命令
- 添加数据
zadd key scorel member1 [score2 member2]
- 获取全部数据
zrang key start(开始索引) stop(结束索引) [WITHSCORES] //[WITHSCORES]
zrevrange key start stop [WITHSCORES] 反转
- 删除数据
zrem key member [member ...]
- 获取集合数据总量
zcard key