网站首页 > 基础教程 正文
满怀忧思,不如先干再说!
前言
上节我们说到Redis的下载和安装,本章说一下Redis的常用命令。基本要求是了解都有哪些命令,不同的数据类型如何存取数据即可。以便后期使用Java语言操作Redis的时候知道它的实现方式其实就是对命令的封装!!!
命令分类
- 通用命令
- 字符串类型
- 哈希类型
- 列表类型
- 集合类型
- 有序集合类型
通用命令
这里列出我们常用的命令,全部命令请参考redis官网:【平台限制:地址放到评论区】
keys pattern
说明:遍历出所有的key,*为pattern参数,也就是匹配符,类似于正则表达式,keys命令一般不推荐在生产环境中使用,因为如果我们的key非常多,检索起来就非常慢,这个命令比较重,而且redis是单线程的会阻塞其他的命令,如果我们需要检索key,可以使用scan命令
127.0.0.1:6379> keys *
1) "k1"
dbsize
说明:计算key的总数
127.0.0.1:6379> dbsize
(integer) 1
exists key
说明:查看key是否存在,返回值 1存在,0不存在
127.0.0.1:6379> exists k1
(integer) 1
127.0.0.1:6379> exists k2
(integer) 0
del key[key...]
说明:删除指定的一个key或者一组key,返回值是删除key的个数
127.0.0.1:6379> del k1
(integer) 1
expire key seconds
说明:设置key的过期时间,单位为秒,返回值1说明设置成功,返回0说明key不存在或设置失败
127.0.0.1:6379> expire k4 30
(integer) 1
pexpire key milliseconds
说明:以毫秒为单位设置过期时间
127.0.0.1:6379> pexpire k5 90000
(integer) 1
ttl key
说明:查看key的过期时间,以秒为单位,返回值-1永不过期,-2已过期
127.0.0.1:6379> ttl k5
(integer) 87
pttl key
说明:查看key的过期时间以毫秒为单位
127.0.0.1:6379> pttl k1
(integer) 76151
persist key
说明:移除key的过期时间
127.0.0.1:6379> persist k1
(integer) 1
127.0.0.1:6379> ttl k1
(integer) -1
type key
说明:返回key对应的数据类型,分别为string、list、set、zset、hash五种数据类型,如果key不存在返回none
127.0.0.1:6379> type k1
string
127.0.0.1:6379> type k2
none
Redis实现原理
数据结构和内部编码
Redis中的五种数据结构,每一种都有两种以上的内部实现,多种内部编码实现可以在不同应用场景下发挥各自优势。具体的编码实现后边补充一篇文章单独去说!
redis单线程
redis是单线程的,在同一个瞬间只可能执行一条命令
那么为什么redis的单线程会这么快呢?
1、主要原因是redis是纯内存操作,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)速度非常快
2、使用多路I/O复用模型,非阻塞I/O
3、单线程避免线程切换和竞态消耗,单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程处理所有网络请求,其他模块仍用了多个线程。
注意
1、一次只执行一条命令
2、拒绝长(慢)命令
keys、flushall、flushdb、slow lua script等时间复杂度高的
String
说明
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。value可以是简单字符串,也可以是复杂的字符串比如JSON,XML等,也可以是数字(小数、整数),甚至是图片或者序列化后的对象,value是一个安全的二进制数据,string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
String类型的使用场景:用来做缓存、计数器、分布式锁等等。
常用命令
set key value : 设置 key 对应 string 类型的值, 返回 1 表示成功, 0 失败。(说明,设置key多次会覆盖)
setnx(not exist) key value: 如果 key 不存在进行设置,存在就不需要进行设置了,返回0
set key value [ex seconds/px milliseconds]: 设置值的同时设置过期时间
get key: 获取 key 对应的 string 值,如果 key 不存在返回 nil(在redis中nil代表为空)
getset key value : 先获取 key 的值,再设置 key 的值。
mset key1 value1 … : 一次设置多个 key 的值, 成功返回 1 表示所有的值都设置了,失败返回 0 表示没有任何值被设置。
mget key1 key2 … keyN : 一次获取多个 key 的值
msetnx key1 value1 … : 一次设置多个 key 的值,但是不会覆盖已经存在的 key
incr key: 递增,注意 incr 一个不是 int 的 value 会返回错误,incr 一个不在的 key,则设置 key 值为 1。
decr key : 递减, decr 一个不存在 key,则设置 key 值为-1。
incrby key integer: 对 key 加上指定值 , key 不存在设置 key,并认为原来的 value是 0。
decrby key integer: 对 key 减去指定值。decrby 完全是为了可读性,我们完全可以通过 incrby一个负值来实现同样效果,反之一样。
incrbyfloat key float:增加对应的浮点数,没有减去指定值,我们可以传入负数来实现该功能
append[key]方法: 字符串追加方法
strlen[key]方法: 获取字符串的长度
getrange key startindex endstart 获取指定范围的字符串
setrange key 10 value(10表示从第几位开始替换,后面跟上替换的字符串)
Hash
说明
Hash类型是String类型的field和value的映射表,或者说一个String集合。它特别适合存储对象相比较而言,将一个对象类型存储在Hash类型里要比存储在String类型里占用更少的内存空间并方便存取整个对象
Hash应用场景:用一个对象来存储用户信息,商品信息,订单信息等等。
常用命令
hset key field value: 设置 hash field 为指定值,如果 key 不存在,则创建
hget key field : 获取指定的 hash field。
hmget key filed1…fieldN : 获取全部指定的 hash filed。
hmset key filed1 value1 … filedN valueN : 同时设置 hash 的多个 field。
hincrby key field integer: 指定步长增加。成功返回 hash filed 变更后的值。
hexists key field : 检测指定 field 是否存在。
hdel key field: 删除指定的 hash field。
hlen key: 返回指定 hash 的 field 数量。
hkeys key: 返回 hash 的所有 field。
hvals key : 返回 hash 的所有 value。
hgetall : 返回 hash 的所有 filed 和 value
与String对比
存储用户信息使用String和Hash存储有什么区别?
使用String类型存储
用户ID为查找的key,存储的value用户对象包含姓名,年龄,生日等信息,如果用普通的key/value结构来存储,主要有以下2种存储方式:
方式一:
第一种方式将用户ID作为查找key,把其他信息封装成一个对象以序列化的方式存储,这种方式的缺点是,增加了序列化/反序列化的开销,并且在需要修改其中一项信息时,需要把整个对象取回,并且修改操作需要对并发进行保护,引入CAS等复杂问题。
方式二:
第二种方法是这个用户信息对象有多少成员就存成多少个key-value对,用户ID+对应属性的名称作为唯一标识来取得对应属性的值,虽然省去了序列化开销和并发问题,但是用户ID为重复存储,如果存在大量这样的数据,内存浪费还是非常可观的
Hash存储
Redis的Hash实际是内部存储的Value为一个HashMap,并提供了直接存取这个Map成员的接口,Key仍然是用户ID, value是一个Map,这个Map的key是成员的属性名,value是属性值,这样对数据的修改和存取都可以直接通过其内部Map的Key(Redis里称内部Map的key为field), 也就是通过 key(用户ID) + field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题,很好的解决了问题。
List
说明
list 列表是简单的字符串列表,按照插入顺序排序,数据可以重复。你可以添加一个元素到列表的头部(左边)或者尾部(右边),既可以作为栈,又可以作为队列
常用命令
lpush key string: 在 key 对应 list 的头部添加字符串元素,返回 1 表示成功, 0 表示 key 存在且不是 list 类型。
rpush key string: 在 key 对应 list 的尾部添加字符串元素
llen key: 返回 key 对应 list 的长度, 如果 key 不存在返回 0
lrange key start end: 返回指定区间内的元素, 下标从 0 开始, 负值表示从后面计算, -1 表示倒数第一个元素 , key 不存在返回空列表。
ltrim key start end : 截取 list 指定区间内元素,成功返回 OK, key 不存在返回错误。
lset key index value: 设置 list 中指定下标的元素值,成功返回 1, key 或者下标不存在返回错误。
lrem key count value : 从 List 的头部(count 正数)或尾部(count 负数)删除一定数量(count)匹配 value 的元素,返回删除的元素数量。count 为 0 时候删除全部。
lpop key: 从 list 的头部删除并返回删除元素。
rpop key: 从 list 的尾部删除并返回删除元素
rpoplpush source destination: 从source列表中删除最后一个元素,添加到des列表中第一个
lindex key index: 返回名称为key的list中index位置的元素
linsert key BEFORE|AFTER pivot value:把 value 插入存于 key 的列表中在基准值 pivot 的前面或后面
List应用场景:好友列表,粉丝列表,消息队列,最新消息排行等
Set
说明
set是string类型的无序集合。集合是通过hashtable实现的,概念和数学中集合基本类似,可以交集,并集,差集等等,set中的元素是没有顺序并且不可重复。所以添加,删除,查找的复杂度都是O(1)
常用命令
sadd key member: 添加一个 string 元素到 key 对应 set 集合中,成功返回 1,如果元素以及在集合中则返回 0, key 对应的 set 不存在则返回错误。
srem key member: 从 key 对应 set 中移除指定元素,返回删除个数,集合中不存在或者key不存在返回 0,如果 key 对应的不是 set 类型的值返回错误。
spop key [count]: 删除并返回 key 对应 set 中随机的一个元素,如果 set 是空或者 key 不存在返回nil。
srandmember key [count]: 随机取 set 中的一个元素,但是不删除元素。
smove srckey dstkey member: 从 srckey 对应 set 中移除 member 并添加到 dstkey 对应 set 中,整个操作是原子的。 成功返回 1,如果 member 在 srckey 中不存在返回 0, 如果 key 不是 set类型返回错误。相当于剪切复制
scard key: 返回 set 的元素个数,如果 set 是空或者 key 不存在返回 0。
sismember key member: 判断 member 是否在 set 中,存在返回 1, 0 表示不存在或者 key 不存在。
sinter key1 key2 …… keyN : 返回所有给定 key 的交集。
sinterstore dstkey key1 … keyN : 返回所有给定 key 的交集, 并保存交集存到 dstkey 下。
sunion key1 key2 … keyN: 返回所有给定 key 的并集。
sunionstore dstkey key1 … keyN: 返回所有给定 key 的并集, 并保存并集到
dstkey sdiff key1 key2 … keyN: 返回所有给定 key 的差集。
sdiffstore dstkey key1 … keyN: 返回所有给定 key 的差集,并保存差集到
dstkey smembers key: 返回 key 对应 set 的所有元素,结果是无序的,如果集合中数据很多,不建议使用
scan key:扫描数据
Set应用场景:共同关注、共同喜好、二度好友、分类标签等功能
sorted set(Zset)
说明
sorted set 是有序集合, 它在 set 的基础上增加了一个顺序属性(score),这一属性在添加,修改元素的时候可以指定, 每次指定后, 会自动重新按新的值调整顺序。 可以理解了有两列的mysql 表,一列存 value,一列存score
常用命令
zadd key score member: 添加元素到集合,元素在集合中存在则更新对应
score zrem key member: 删除指定元素, 1 表示成功,如果元素不存在返回 0
zincrby key incr member : 增加对应 member 的 score 值, 然后移动元素并保持 skip list 保持有序。返回更新后的 score 值
zrank key member : 返回指定元素在集合中的排名(下标), 集合中元素是按 score 从小到大排序的
zrevrank key member : 同上,但是集合中元素是按 score 从大到小排序
zrange key start end : 类似 lrange 操作从集合中去指定区间的元素。返回的是有序结果
zrevrange key start end: 同上,返回结果是按 score 逆序的
zrangebyscore key min max: 返回集合中 score 在给定区间的元素
zcount key min max: 返回集合中 score 在给定区间的数量 zcard key: 返回集合中元素个数
zscore key element: 返回给定元素对应的 score
sorted set使用场景:排行榜等
更多命令可以到Redis官网,因不能放置外链,将链接放到评论区,大家可以自行食用,如果不错记得关注,点赞哦!
- 上一篇: Redis分享之你不可不知的Redis常用命令
- 下一篇: redis五大数据类型之sortedset
猜你喜欢
- 2025-01-04 收藏|空调、制冷仪器、仪表词汇中英文对照表
- 2025-01-04 纽扣电池型号CR2025和CR2032有什么区别-道合顺大数据Infinigo
- 2025-01-04 【Golang】go-redis使用(转载)
- 2025-01-04 redis zset命令详解
- 2025-01-04 Redis 中ZSET数据类型命令使用及对应场景总结
- 2025-01-04 Redis 常用数据类型之 zset(有序集合)
- 2025-01-04 一文搞懂Redis
- 2025-01-04 Redis数据持久化机制、主从同步原理、常见规范与优化详解
- 2025-01-04 Redis概述
- 2025-01-04 redis五大数据类型之sortedset
- 01-09Oracle数据库面试题汇总
- 01-09Oracle AWR解析-Report Summary
- 01-09想要成为数据分析师,这些Excel必备知识点你得掌握
- 01-09java开发中常用Oracle函数实例总结比较,当真不少
- 01-09DriveWorks其实是这么回事
- 01-09EXCEL做数据分析,学会这些就入门了
- 01-09一场pandas与SQL的巅峰大战(六)
- 01-09Oracle数据库知识 day01 Oracle介绍和增删改查
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)