Reids入门基本命令,学习使我快乐02,关于reidis 的一些操作命令(五大基本数据类型)

Redis 五大数据类型

官方文档
在这里插入图片描述
全段翻译:
Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库高速缓存消息队列代理。它支持字符串、哈希表、列表、集合、有序集合,位图,hyperloglogs等数据类型。内置复制、Lua脚本、LRU收回、事务以及不同级别磁盘持久化功能,同时通过Redis Sentinel提供高可用,通过Redis Cluster提供自动分区。

我们现在讲解所有的命令大家
单点登录

Redis-Key


127.0.0.1:6379[1]> set name kuangshen   #设置name 值
OK
127.0.0.1:6379[1]> keys *  #显示所有的key
1) "age"
2) "name"
127.0.0.1:6379[1]> set age 1  #设置age 为1
OK
127.0.0.1:6379[1]> keys *     #显示所有的key
1) "age"
2) "name"
127.0.0.1:6379[1]> EXISTS name  #是否存在key 为name 的值,返回1 表示有
(integer) 1
127.0.0.1:6379[1]> EXISTS name1 #是否存在key 为name1 的值 返回0 表示没有
(integer) 0
127.0.0.1:6379[1]> move name 1  #将name 移动到数据库1 的环境下面,移动失败
(error) ERR source and destination objects are the same
127.0.0.1:6379[1]> move name 14   #将name 移动到数据库14 的环境下面,移动成功
(integer) 1
127.0.0.1:6379[1]> keys *   #显示所有的key
1) "age"
127.0.0.1:6379[1]> set name qinjiang  #设置name 为qinjiang
OK
127.0.0.1:6379[1]> keys *  #显示所有的key
1) "age"
2) "name"
127.0.0.1:6379[1]> get name #获取name value 的值
"qinjiang"
127.0.0.1:6379[1]> EXPIRE name 10 #设置key的过期时间,单位是秒
(integer) 1
127.0.0.1:6379[1]> ttl name  #查看当前key 的剩余时间
(integer) 2
127.0.0.1:6379[1]> ttl name  #查看当前key 的剩余时间,返回-2,name已经过期了
(integer) -2
127.0.0.1:6379[1]> get name  
(nil)
127.0.0.1:6379> type name  #查看当前key的一个类型
string
127.0.0.1:6379> type age #查看 age 的一个类型
string

后面如果遇到不会的命令,可以查看官方的文档!
在这里插入图片描述
String(字符串)

90% 的java 程序员使用redis 只会使用一个String 类型!


127.0.0.1:6379> flushall   ## 清除所有数据
OK
127.0.0.1:6379> set key1 v1  ## 设置key1 v1
OK
127.0.0.1:6379> get key1  ##获取key1 的value 值
"v1" 
127.0.0.1:6379> keys *  ## 查看所有的keys 值
1) "key1"
127.0.0.1:6379> EXISTS key1 ## 查看key1 是否存在
(integer) 1
127.0.0.1:6379> APPEND key1 "hello"  ##追加字符串,如果当前key 不存在,就相当于setkey
(integer) 7
127.0.0.1:6379> get key1
"v1hello"
127.0.0.1:6379> STRLEN key1 #获取字符串的长度
(integer) 7
127.0.0.1:6379> APPEND key1 "kuangshen"
(integer) 16
127.0.0.1:6379> get key1
"v1hellokuangshen"
127.0.0.1:6379>

127.0.0.1:6379> set views 0  #初始化浏览量为0
OK
127.0.0.1:6379> get views
"0"
127.0.0.1:6379> INCR views  #自增1 
(integer) 1
127.0.0.1:6379> get views
"1"
127.0.0.1:6379>

127.0.0.1:6379> decr views  #自减1  浏览量-1
(integer) 0
127.0.0.1:6379> decr views #减1,直接查看结果
(integer) -1
127.0.0.1:6379> INCRBY views 10  # i+10  #可以设置步长,定期增量
(integer) 9
127.0.0.1:6379> DECRby views 10  # i-10
(integer) -1
127.0.0.1:6379>
#字符串范围  range
27.0.0.1:6379> set key1 "hell0,kuangshen"  # 设置key1 的值
OK
127.0.0.1:6379> get key1  #获取key1 的value
"hell0,kuangshen"
127.0.0.1:6379> GETRANGE key1 0 3  #截取字符串[0,3]的字符,相当于java 的substr
"hell"
127.0.0.1:6379> GETRANGE key1 0 -1 #获取全部的数据和get key 是一样的
"hell0,kuangshen"
# 替换

127.0.0.1:6379> SETRANGE key2  1 xx  #替换指定位置开始的字符串!
(integer) 7
127.0.0.1:6379> get key2
"axxdefg"
127.0.0.1:6379>
####################################
#setex(set with expire) #设置过期时间
#setnx(set if not exist) #不存在设置 (在分布式锁中长使用!)
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> setex key3 30 # 设置key3 的值位hello,30s 后过期
(error) ERR wrong number of arguments for 'setex' command
127.0.0.1:6379> setex key3 39 "hello"
OK
127.0.0.1:6379> ttl key3
(integer) 34
127.0.0.1:6379> get key3
"hello"
127.0.0.1:6379> setnx mykey "redis" #如果mykey 不存在,创建mukey
(integer) 1
127.0.0.1:6379> keys *
1) "mykey"
2) "key3"
127.0.0.1:6379> ttl key3
(integer) 11
127.0.0.1:6379> ttl key3
(integer) 6
127.0.0.1:6379> ttl key3
(integer) 3
127.0.0.1:6379> ttl key3
(integer) -2
127.0.0.1:6379> setnx mykey "MongDb" # 如果mykey 存在,创建失败!
(integer) 0
127.0.0.1:6379> get mykey
"redis"
127.0.0.1:6379>
###################################
mset
mget
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> mset key1 v1 key2 v2
OK
127.0.0.1:6379> mget key1 key2
1) "v1"
2) "v2"
127.0.0.1:6379> keys *
1) "key2"
2) "key1"

127.0.0.1:6379> FLUSHALL
OK
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3  # 同时获取多个值
OK
127.0.0.1:6379> mget k1 k2 k3
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> msetnx k1 v1 k5 v4 #msetnx 是一个原子性的操作,要么一起成功,要么一起失败(原子性)
(integer) 0
127.0.0.1:6379> get k5
(nil)
#对象
set user:1     {name:zhangsan,age:3}  #设置一个user:1 对象 值位json 字符串来保存一个对象
这里的key 是一个巧妙的设计 user:{id}:{flied},如此设计在redis 中是完全ok!
##################################
getset # 先get然后再set
127.0.0.1:6379> flushall
OK
127.0.0.1:6379> getset db redis # 如果不存在的值,则返回nil
(nil)
127.0.0.1:6379> get db
"redis"
127.0.0.1:6379> getset db mongodb # 如果存在值,获取原来的值,并设置新的值
"redis"
127.0.0.1:6379> get db
"mongodb"
127.0.0.1:6379>

###################################

数据结构是相同的。未来的话, 这些都会编程jedis 的方法!
String 类似的使用场景:value 除了是我们的字符串,还可以使我们的数字!
· 计数器
· 统计多单位的数量 uid:95256449:follow 0
· 粉丝数
· 对象存储值!

List 的一些操作命令

基本的数据类型,列表,可以做队列,可以做栈
+
在redis 里面,我们可以把list 完成,栈,队列,阻塞队列!
所有的list 命令都是用l 来开头的,Redis 不区分大小命令

127.0.0.1:6379> LPUSH list one  #将一个值或者多个值,插入到列表的头部(左)
(integer) 1
127.0.0.1:6379> Lpush list two
(integer) 2
127.0.0.1:6379> lpush list three
(integer) 3
127.0.0.1:6379> Lrange list 0 -1  #获取list 中的值!
1) "three"
2) "two"
3) "one"
127.0.0.1:6379> LRANGE list 0 1 #通过区间获取具体的值!
1) "three"
2) "two"

127.0.0.1:6379> RPUSH list righr
(integer) 4
127.0.0.1:6379> LRANGE list 0 -1 #将一个值或者多个值,插入到列表的尾部(右)
1) "three"
2) "two"
3) "one"
4) "righr"
127.0.0.1:6379>
################################## 移除POP
lPOP
rPOP

127.0.0.1:6379> Lpop list   #移除list的第一个元素
"three"
127.0.0.1:6379> RPOP list  #移除list 的最后一个元素
"righr"
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> LRANGE list 0 -1
1) "two"
2) "one" 
################################## Lindex
Lindex 下标

127.0.0.1:6379> LINDEX list 0   
"two"
127.0.0.1:6379> LINDEX list 1   #根据下标获取list 中的某一个值
"one"
##################################  获取list 长度
Llen
127.0.0.1:6379> LPUSH list one #给list 添加值
(integer) 1
127.0.0.1:6379> LPUSH list two #给list 添加值
(integer) 2
127.0.0.1:6379> LPUSH list three #给list 添加值
(integer) 3
127.0.0.1:6379> llen list  #获取list 长度
(integer) 3
##################################  移除指定的值
Lrem
127.0.0.1:6379> flushdb  #清除当前库所有的数据
OK
127.0.0.1:6379> lrange list 0 -1 # 查询当前list 下所有的数据
(empty list or set)
127.0.0.1:6379> lpush list one #给list 添加值
(integer) 1
127.0.0.1:6379> lpush list two #给list 添加值
(integer) 2
127.0.0.1:6379> lpush list three #给list 添加值
(integer) 3
127.0.0.1:6379> lrange list  0 -1 # 查询当前list 下所有的数据
1) "three"
2) "two"
3) "one"
127.0.0.1:6379> lrem list 1 one #删除一个value 值为one 的数据
(integer) 1
127.0.0.1:6379> range
(error) ERR unknown command `range`, with args beginning with:
127.0.0.1:6379> LRANGE list 0 -1  # 查询当前list 下所有的数据
1) "three"
2) "two"
127.0.0.1:6379> lpush list two  #给list 添加值
(integer) 3
127.0.0.1:6379> lrange list 0 01 #给list 添加值
(error) ERR value is not an integer or out of range
127.0.0.1:6379> lrange list 0 -1  # 查询当前list 下所有的数据
1) "two"
2) "three"
3) "two"
127.0.0.1:6379> lrem list 2 two #删除两个个value 值为two的数据
(integer) 2
127.0.0.1:6379> lrange list 0 -1 # 查询当前list 下所有的数据
1) "three"
##################################  trim 通过下标截取指定的长度
127.0.0.1:6379> LPUSH mylist hello
(integer) 1
127.0.0.1:6379> LPUSH mylist hello1
(integer) 2
127.0.0.1:6379> LPUSH mylist hello2
(integer) 3
127.0.0.1:6379> LPUSH mylist hello3
(integer) 4
127.0.0.1:6379> LTRIM mylist 1  3  # 通过下标截取指定的长度
OK
127.0.0.1:6379> lrange mylist 0 -1
1) "hello2"
2) "hello1"
3) "hello"
##################################
rpoplpush #移除列表的最后一个元素,将他移动到新的列表中
127.0.0.1:6379> rpush mylist "hello1"
(integer) 1
127.0.0.1:6379> rpush mylist "hello"
(integer) 2
127.0.0.1:6379> rpush mylist "hello3"
(integer) 3
127.0.0.1:6379> rpush mylist "hello2"
(integer) 4
127.0.0.1:6379> LRANGE mylist 0 -1  #移除列表的最后一个元素,将他移动到新的列表中
1) "hello1"
2) "hello"
3) "hello3"
4) "hello2"
127.0.0.1:6379> rpoplpush mylist myotherlist
"hello2"
127.0.0.1:6379> LRANGE mylist 0 -1 # 查看原来的列表
1) "hello1"
2) "hello"
3) "hello3"
127.0.0.1:6379> LRANGE myotherlist 0 -1 #查看目标的列表中,确实存在的值!
1) "hello2"
127.0.0.1:6379>
################################## lset 将列表中指定下标的值替换为另外一个值,更新操作
127.0.0.1:6379> EXISTS list   # 判断这个列表是否存在
(integer) 0
127.0.0.1:6379> lset list 0 item  #如果不存在列表我们去更新就会报错
(error) ERR no such key
127.0.0.1:6379> lpush list value1
(integer) 1
127.0.0.1:6379> LRANGE list 0 0
1) "value1"
127.0.0.1:6379> lset list 0 item  # 如果存在,更新当前下标的值
OK
127.0.0.1:6379> LRANGE list 0 0
1) "item"
127.0.0.1:6379> lset list 1 other  # 如果不存在,则会报错
(error) ERR index out of range
################################## linsert 将具体的某个value 插入到列表的前面或者后面
linsert
27.0.0.1:6379> rpush mylist "hello"
(integer) 1
127.0.0.1:6379> rpush mylist "world"
(integer) 2
127.0.0.1:6379> linsert mylist before "world" "other"
(integer) 3
127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "other"
3) "world"
127.0.0.1:6379> LINSERT mylist after world new
(integer) 4
127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "other"
3) "world"
4) "new"

小结

  • 它实际上是一个链表,before Node after ,left ,right 都可以插入值
  • 如果key 不存在,创建新的链表
  • 如果key 存在,新增内容
  • 如果移除了key 所有的值都消失了
  • 在两边插入或者改动值,效率高!中间元素,相对来说效率会低一点

消息排队! 消息队列 LPUSH Rpoop 栈(Lpush Lpoop)

Set(集合)

set 中的值是不能重复的!

################################################
127.0.0.1:6379> sadd myset "hello"   #set 集合中添加元素
(integer) 1
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> sadd myset ▒"kuangshen"
(integer) 1
127.0.0.1:6379> sadd myset "lovekuangshen"
(integer) 1
127.0.0.1:6379> SMEMBERS myset #查看指定set 的所有值
1) "lovekuangshen"
2) "\x80kuangshen"
3) "hello"
127.0.0.1:6379> SISMEMBER myset hello #判断某一个元素是不是在set 集合中!
(integer) 1
127.0.0.1:6379> SISMEMBER myset workd
(integer) 0
################################################获取set 集合中的内容元素个数
127.0.0.1:6379> scard myset  查看个数
(integer) 3
127.0.0.1:6379> sadd myset "lovekuangshen2"
(integer) 1
127.0.0.1:6379> scard myset
(integer) 4
127.0.0.1:6379>
################################################移除set 中指定的元素
127.0.0.1:6379> srem myset "hello"
(integer) 1
127.0.0.1:6379> scard
(error) ERR wrong number of arguments for 'scard' command
127.0.0.1:6379> SCARD myset
(integer) 3
127.0.0.1:6379> SMEMBERS myset
1) "lovekuangshen2"
2) "lovekuangshen"
3) "\x80kuangshen"
127.0.0.1:6379>
[root@VM-0-6-centos bin]#
################################################移除set 中指定的元素
set 无序不重复集合,抽随机
127.0.0.1:6379> SRANDMEMBER myset   #随机抽选出一个元素
"\x80kuangshen"
127.0.0.1:6379>
127.0.0.1:6379> SRANDMEMBER myset
"\x80kuangshen"
127.0.0.1:6379> SRANDMEMBER myset
"tian"
127.0.0.1:6379> SRANDMEMBER myset 2  # 随机获取2 个元素
"lovekuangshen"
1) "tian"
################################################ 移除一个指定的key,随机删除一个key!

127.0.0.1:6379> SMEMBERS myset 
1) "\x80kuangshen"
2) "tian"
3) "lovekuangshen2"
4) "zhh"
5) "lovekuangshen"
127.0.0.1:6379> spop myset   #随机删除一些set 中的元素
"\x80kuangshen"
127.0.0.1:6379> spop myset
"tian"
127.0.0.1:6379> SMEMBERS myset
1) "lovekuangshen2"
2) "zhh"
3) "lovekuangshen"
127.0.0.1:6379>
################################################ 将一个指定的值,移动到另外一个set中

127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> sadd myset "world"
(integer) 1
127.0.0.1:6379> sadd myset "hello"
(integer) 1
127.0.0.1:6379> sadd myset "hello2"
(integer) 1
127.0.0.1:6379> sadd myset2 kuangshen  
(integer) 1
127.0.0.1:6379>
127.0.0.1:6379>
127.0.0.1:6379> smove myset myset2 hello2
(integer) 1
127.0.0.1:6379> SMEMBERS myset2
1) "kuangshen"
2) "hello2"
127.0.0.1:6379>
################################################ 
微博b 站,共同关注! 并集
数字集合类:
-差集
-交集
127.0.0.1:6379> sadd key1 a
(integer) 1
127.0.0.1:6379> sadd key1 b
(integer) 1
127.0.0.1:6379> sadd key1 c
(integer) 1
127.0.0.1:6379> sadd key2 d
(integer) 1
127.0.0.1:6379> sadd key2 e
(integer) 1
127.0.0.1:6379> SDIFF key1 key2
1) "a"
2) "c"
3) "b"
127.0.0.1:6379> sadd key2 c
(integer) 1
127.0.0.1:6379> sadd key2 c
(integer) 0
127.0.0.1:6379> SDIFF key1 key2 # 差集
1) "a"
2) "b"
127.0.0.1:6379> SMEMBERS key1
1) "c"
2) "a"
3) "b"
127.0.0.1:6379> SMEMBERS key2
1) "c"
2) "e"
3) "d"
127.0.0.1:6379> SINTER key1 key2 #交集
1) "c"
127.0.0.1:6379> SUNION key1 kye2 #并集

1) "e"
2) "a"
3) "c"
4) "b"
5) "d"

微博,A 用户将所有关注的人放在一个set 集合中!,将他的粉丝也放在一个集合中!
A ,B 用共同关注可以看出来,推荐好友(六度分割理论)

#Hash(哈希)
Map 集合key-Map集合! 这时候这个值是一个map 集合!本质和String 类型没有太大区别,还是一个简单的key-value
set myhash filed kuangshen

127.0.0.1:6379> hset myhash filed1 kuangshen  #set 一个具体 key-value
(integer) 1
127.0.0.1:6379> hget myhash filed1 # 获取一个字段值
"kuangshen"
127.0.0.1:6379> hmset myhash filed1 hello filed2 world #set 多个key -value
OK
127.0.0.1:6379> hmget myhash filed1 filed2 # 获取多个字段值
1) "hello"
2) "world"
127.0.0.1:6379> hgetall myhash # 获取全部的数据
1) "filed1"
2) "hello"
3) "filed2"
4) "world"

127.0.0.1:6379> hdel myhash filed1  #删除hash 指定key 字段,对应的value 值也消失了!
(integer) 1
127.0.0.1:6379> hgetall myhash
1) "filed2"
2) "world"
################################################ 
hlen 获取hash 表的长度
127.0.0.1:6379> hmset myhash filed1 hello filed2 world
OK
127.0.0.1:6379> hgetall myhash
1) "filed1"
2) "hello"
3) "filed2"
4) "world"
127.0.0.1:6379> hlen myhash     #获取hash表的字段数量
(integer) 2
################################################ 
127.0.0.1:6379> HEXISTS myhash filed3  # 判断hash 中的指定字段是否存在!
(integer) 0
127.0.0.1:6379> HEXISTS myhash filed1
(integer) 1
################################################ 
# 只获取所有的filed
# 只获取所有的value
127.0.0.1:6379> hkeys myhash  #只获取的所有filed
1) "filed1"
2) "filed2"
127.0.0.1:6379> hvals myhash #只获取所有的value
1) "hello"
2) "world"
################################################ 

127.0.0.1:6379> hset myhash filed3 5
(integer) 1
127.0.0.1:6379> HINCRBY myhash  filed3 -1   #指定增量!
(integer) 4
127.0.0.1:6379> hsetnx myhash filed 4 #如果不存在则可以设置
(integer) 1
127.0.0.1:6379> hsetnx myhash filed 4 #如果存在则不能设置
(integer) 
127.0.0.1:6379> hset user:1 name qingjiang
(integer) 1
127.0.0.1:6379> hget user:1 name
"qingjiang"
127.0.0.1:6379> hset myhash filed3 5
(integer) 1
127.0.0.1:6379> HINCRBY myhash filed3 1 # 固定增量
(integer) 6
127.0.0.1:6379> HINCRBY myhash filed3 -1  # 固定增量
(integer) 5

hash 变更的数据user name age,尤其是用户信息之类的,经常变动的信息!hash 更适合于对象的存储,String 更适合存储字符串!
Zset(有序集合)
在set 的基础上,增加了一个只,set k1,v1 zet k1 score1 v1

127.0.0.1:6379> zadd myset 1 one    # 添加一个值
(integer) 1
127.0.0.1:6379> zadd myset 2  two
(integer) 1
127.0.0.1:6379> zadd myset 3 two 4 three  # t添加多个值
(integer) 1
127.0.0.1:6379> ZRANGE mset 0 -1
(empty list or set)
127.0.0.1:6379> ZRANGE myset 0 -1
1) "one"
2) "two"
3) "three"
################################
排序如何实现
127.0.0.1:6379> zadd salary 2500 xiaohong
(integer) 1
127.0.0.1:6379> zadd salay 5000 zhangsan
(integer) 1
127.0.0.1:6379> zadd salary 500 kuangshen
(integer) 1
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf
1) "kuangshen"
2) "xiaohong"
127.0.0.1:6379> zadd salary 2500 xiaohong
(integer) 1
127.0.0.1:6379> zadd salay 5000 zhangsan
(integer) 1
127.0.0.1:6379> zadd salary 500 kuangshen
(integer) 1
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf
1) "kuangshen"
2) "xiaohong"
127.0.0.1:6379> ZRANGEBYSCORE salary -0 -1
(empty list or set)
127.0.0.1:6379> ZRANGEBYSCORE salary 0 -1
(empty list or set)
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf withscores  #x显示全部的用户并且附带成绩
1) "kuangshen"
2) "500"
3) "xiaohong"
4) "2500"
127.0.0.1:6379> ZRANGEBYSCORE salary -inf 1000  withscores #显示工资小于2500 员工的降序
1) "kuangshen"
2) "500"
################################
移除rem 中的元素
127.0.0.1:6379> ZRANGEBYSCORE salary -inf 1000  withscores
1) "kuangshen"
2) "500"
127.0.0.1:6379> ZRANGE salary 0 -1   #显示所有的数据
1) "kuangshen"
2) "xiaohong"
127.0.0.1:6379> zrem salary xiaohong  # 移除指定的特殊元素
(integer) 1
127.0.0.1:6379> ZRANGE salary - 0 -1
(error) ERR value is not an integer or out of range
127.0.0.1:6379> ZRANGE salary  0 -1
1) "kuangshen"
127.0.0.1:6379> zcard salary   #获取有序集合中的个数
(integer) 1
################################
127.0.0.1:6379> zadd salary 2500 xiaohong   #添加三个用户
(integer) 1
127.0.0.1:6379> zadd salary 6000 zhuangsan
(integer) 1
127.0.0.1:6379> zadd salay 700 kuangshen
(integer) 1
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf  #显示全部的用户 从小到大
1) "xiaohong"
2) "zhuangsan"
127.0.0.1:6379> ZADD salary 500 kuangshen
(integer) 1
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf
1) "kuangshen"
2) "xiaohong"
3) "zhuangsan"
127.0.0.1:6379> ZREMRANGEBYSCORE salay 0 -1  #从大到小进行排序
(integer) 0
127.0.0.1:6379> ZREMRANGEBYSCORE salary 0 -1
(integer) 0
127.0.0.1:6379> ZREVRANGE salary 0 -1
1) "zhuangsan"
2) "xiaohong"
3) "kuangshen"
127.0.0.1:6379> ZREVRANGE salary -inf +inf withscores
(error) ERR value is not an integer or out of range
127.0.0.1:6379> ZRANGEBYSCORE salary -inf +inf withscores  #显示全部的用户并且附加成绩
1) "kuangshen"
2) "500"
3) "xiaohong"
4) "2500"
5) "zhuangsan"
6) "6000"
127.0.0.1:6379> ZRANGEBYSCORE salay -inf 2500 withscores #显示工资小于2500 员工的升序排序
1) "kuangshen"
2) "700"
################################
127.0.0.1:6379> zadd myset 1 hello  #添加4个值
(integer) 1
127.0.0.1:6379> zadd myset 2 world
(integer) 1
127.0.0.1:6379> zadd myset 3 zhao 4 tian
(integer) 2
127.0.0.1:6379> ZRANGE myset 0 -1  #显示myset 中的value
1) "hello"
2) "world"
3) "zhao"
4) "tian"
127.0.0.1:6379> ZCOUNT myset 1 3  #查看1到3 之间myset 的数量值
(integer) 3
127.0.0.1:6379> ZCOUNT myset 1 2
(integer) 2

其余的api ,通过我们的学习,如果工作中有需要,这个时候可以去看看官方文档!
案例思路:set 排序,存储班级成绩表,工资表排序!
普通消息,1 , 重要消息2 带权重进行排序

zset 排序榜应用实现,取Top N 测试!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值