《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
| 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
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
序
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
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
[外链图片转存中…(img-6P2hNVKt-1714740424093)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!