| strlen | 获得对应key存储value的长度 |
| append | 为对应key的value追加内容 |
| getrange 索引0开始 | 截取value的内容(range:范围) |
| setex | 设置一个key存活的有效期(秒)(ex=expire) |
| psetex | 设置一个key存活的有效期(毫秒) |
| setnx | 存在不做任何操作,不存在添加 |
| msetnx原子操作(只要有一个存在不做任何操作) | 可以同时设置多个key,只有有一个存在都不保存 |
| decr | 进行数值类型的-1操作 |
| decrby | 根据提供的数据进行减法操作 |
| Incr | 进行数值类型的+1操作 |
| incrby | 根据提供的数据进行加法操作 |
| Incrbyfloat | 根据提供的数据加入浮点数 |
3、常规命令具体实现
(1)设置/获取一个值
| set | 设置一个key/value |
| — | — |
| get | 根据key获得对应的value |
(2)设置多个值/获取多个值
| mset | 一次设置多个key value |
| — | — |
| mget | 一次获得多个key的value |
(3)获取原始的key值,设置新值
| getset | 获得原始key的值,同时设置新值 |
| — | — |
| rename | 修改键的名字 |
(4)获取key对应的值的长度
| strlen | 获得对应key存储value的长度 |
| — | — |
| | |
(5)给key对应的值的追加值
| append | 为对应key的value追加内容 |
| — | — |
| | |
(6)截取value的内容
| getrange 索引0开始 | 截取value的内容(range:范围) |
| — | — |
| | |
(7)创建并且设置key存活的时间(用来做秒杀之类的)
| setex | 设置一个key存活的有效期(秒)(ex=expire) |
| — | — |
| psetex | 设置一个key存活的有效期(毫秒) |
(8)存在不做任何操作,不存在添加一个或多个值
| setnx | 存在不做任何操作,不存在添加 |
| — | — |
| msetnx原子操作(只要有一个存在不做任何操作) | 可以同时设置多个key,只有有一个存在都不保存 |
(9)对字符串中是数值的减少(如果不是数值,如:"12a"就不能执行改操作)
- decrease 减少
| decr | 进行数值类型的-1操作 |
| — | — |
| decrby | 根据提供的数据进行减法操作 |
(10)对字符串中是数值(包含小数点)的增加(如果不是数值,如:"12a"就不能执行改操作)
- Increment:自增
| Incr | 进行数值类型的+1操作 |
| — | — |
| incrby | 根据提供的数据进行加法操作 |
| Incrbyfloat | 根据提供的数据加入浮点数 |
===========================================================================
// list类型 元素有序 且 可以重复
1.内存存储模型
2.常用操作指令
| 命令 | 说明 |
| — | — |
| lpush | 将某个值加入到一个key列表头部 |
| lpushx | 同lpush,但是必须要保证这个key存在 |
| rpush | 将某个值加入到一个key列表末尾 |
| rpushx | 同rpush,但是必须要保证这个key存在 |
| lpop | 返回和移除列表左边的第一个元素 |
| rpop | 返回和移除列表右边的第一个元素 |
| lrange | 获取某一个下标区间内的元素 |
| llen | 获取列表元素个数 |
| lset | 设置某一个指定索引的值(索引必须存在) |
| lindex | 获取某一个指定索引位置的元素 |
| lrem | 删除重复元素 |
| ltrim | 保留列表中特定区间内的元素 |
| linsert | 在某一个元素之前,之后插入新元素 |
3、具体实现
(1)lpush将某个值加入到一个key列表头部
倒序排序,先进去的在后面
lpush users whj yfj zs li ww
(2)lpushx同lpush,但是必须要保证这个key存在
127.0.0.1:6379> lpushx names win7
127.0.0.1:6379> lrange names 0 -1
-
“win7”
-
“whj”
-
“yfj”
-
“zs”
-
“li”
-
“ww”
(3)rpush|将某个值加入到一个key列表末尾
127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
127.0.0.1:6379> rpush users 杨福君
10
127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
(4)rpushx同rpush,但是必须要保证这个key存在
127.0.0.1:6379> rpushx names whj
0
127.0.0.1:6379> rpushx users whj
11
127.0.0.1:6379> lrange users 0 -1
杨福君
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
(5)lpop返回和移除列表左边的第一个元素
127.0.0.1:6379> lrange users 0 -1
zx
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
127.0.0.1:6379> lpop users
zx
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
(6)rpop返回和移除列表右边的第一个元素
从右边弹出来四个
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj
whj
王恒杰
杨福君
whj
127.0.0.1:6379> rpop users
whj
127.0.0.1:6379> rpop users
杨福君
127.0.0.1:6379> rpop users
王恒杰
127.0.0.1:6379> rpop users
whj
127.0.0.1:6379> lrange users 0 -1
dzw
lfk
whx
zxj
yfj
(7)lrange获取某一个下标区间内的元素
lpush users whj yfj dzw zx whx zxj
(8)llen获取列表元素个数
llen users
(9)lset设置某一个指定索引的值(索引必须存在)
lset users 3 lhh
(10)lindex获取某一个指定索引位置的元素
lindex users 3
(11)lrem删除重复元素
rpush users whj
lrem users 2 whj
(12)ltrim 保留列表中特定区间内的元素
ltrim users 0 3
(13)linsert、在某一个元素之前,之后插入新元素
linsert users before whx whj
- 在某个元素之前添一个数
- 在某个数之后添加一个数
linsert users after zx lfk
==========================================================================
key String
vlaue Set集合类型 元素不能存在重复 元素无序 String
特点: Set类型 Set集合 元素无序 不可以重复
1.内存存储模型
2.常用命令
| 命令 | 说明 |
| — | — |
| sadd | 为集合添加元素 |
| smembers | 显示集合中所有元素 无序(member:成员) |
| scard | 返回集合中元素的个数 |
| spop | 随机返回一个元素 并将元素在集合中删除 |
| smove | 从一个集合中向另一个集合移动元素 必须是同一种类型 |
| srem | 从集合中删除一个元素 |
| sismember | 判断一个集合中是否含有这个元素(sis=sister姐妹) |
| srandmember | 随机返回元素(srand:乐趣,根据自己的乐趣返回值) |
| sdiff | 去掉第一个集合中其它集合含有的相同元素 (不会操作原始集合元素) |
| sinter | 求交集(intersection:交集) |
| sunion | 求和集(union:合集) |
(1)sadd:为集合添加元素(无序,自动去重)
sadd names 王恒杰 杨福君周宣君 邓正武 吴洪旭 张茜
(2)smebers:显示集合中所有元素 无序(member:成员)
smembers names
(3)scard:返回集合中元素的个数
scard names
(4)spop:随机返回一个元素 并将元素在集合中删除
spop names
(5)smove:从一个set集合中向另一个set集合移动元素 必须是同一种类型
smove names goodfriend 邓正武
(6)srem:从集合中删除一个元素
srem names 吴洪旭
(7)sismeber:判断一个集合中是否含有这个元素(sis=sister姐妹)
sismember names 张茜
(8)srandmember:随机返回元素(srand:乐趣,根据自己的乐趣返回值)
srandmember names 1
(9)sdiff:去掉第一个集合中其它集合含有的相同元素 (不会操作原始集合元素)
sdiff names goodfriend
(10)sinter:求交集(intersection:交集)
sinter names goodfriend
(11)sunion:求和集(union:合集)
sunion names goodfriend
==========================================================================================
ZSET
特点: 1.不可重复 2.可排序的set集合 根据元素分数进行排序
key String
value ZSET
值=分数+值
1.内存模型
2.常用命令
| 命令 | 说明 |
| — | — |
| zadd | 添加一个有序集合元素 |
| zcard | 返回集合的元素个数 |
| zrange 升序 zrevrange 降序 | 返回一个范围内的元素 |
| zrangebyscore | 按照分数查找一个范围内的元素 (实现分页) |
| zrank | 返回排名 |
| zrevrank | 倒序排名 |
| zscore | 显示某一个元素的分数 |
| zrem | 移除某一个元素 |
| zincrby | 给某个特定元素加分 |
(1)zadd:添加一个有序集合元素
zadd schoolreport 30 杨福君 50 邓正武 70 吴洪旭 100 王恒杰
(2)zcard:返回集合的元素个数
zcard schoolreport
(3)zrange 升序 zrevrange 降序:返回一个范围内的元素
- 返回升序排名zrange
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/c563f2ccf5058b021be87954a019a110.jpeg)
分享
1、算法大厂——字节跳动面试题
2、2000页互联网Java面试题大全
3、高阶必备,算法学习
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
n/img_convert/8058f997fa941ef180a051712d8e6131.png)
(3)zrange 升序 zrevrange 降序:返回一个范围内的元素
- 返回升序排名zrange
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。[外链图片转存中…(img-1cgalXft-1713274750832)]
[外链图片转存中…(img-BOynJdFz-1713274750832)]
[外链图片转存中…(img-BfOYSDOn-1713274750833)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/c563f2ccf5058b021be87954a019a110.jpeg)
分享
1、算法大厂——字节跳动面试题
[外链图片转存中…(img-O9vvNsjT-1713274750833)]
2、2000页互联网Java面试题大全
[外链图片转存中…(img-gPkLRNmt-1713274750833)]
3、高阶必备,算法学习
[外链图片转存中…(img-H1C5mdVd-1713274750833)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!