Redis各数据类型特定的命令和用法 1.0版本
目录
- 一、Sring数据类型
- 1.1 概述
- 1.2 set/get/append/strlen命令
- 1.3 incr/decr/incrby/decrby 命令
- 1.4 getset命令
- 1.5 setex命令
- 1.6 setnx命令
- 1.7 mset/mget/msetnx命令
- 二、List数据类型
- 2.1 概述
- 2.2 lpush/lpushx/lrange命令
- 2.3 lpop/llen命令
- 2.4 lrem/lset/lindex/ltrim命令
- 2.5 linsert命令
- 2.6 rpush/rpushx/rpop/rpoplpush命令
- 三、Hash数据类型(散列类型)
- 3.1 概述
- 3.2 hset/hget/hdel/hexists/hlen/hsetnx命令
- 3.3 hincrby命令
- 3.4 hgetall/hkeys/hvals/hmget/hmset 命令
- 四、Set数据类型(无序集合)
- 4.1 概述
- 4.2 应用范围
- 4.3 sadd/smembers/scard/sismember命令
- 4.4 spop/srem/srandmember/smove 命令
- 五、Sorted Set数据类型(zset、有序集合)
- 5.1 概述
- 5.2 应用范围
- 5.3 zadd/zcard/zcount/zrem/zincrby/zscore/zrange/zrank命令
- 5.4 zrangebyscore/zremrangebyrank/zremrangebyscore命令
- 5.5 zrevrange/zrevrangebyscore/zrevrank命令
redis-cli -a 'abc123'
一、Sring数据类型
1.1 概述
String是redis最基本的类型,最大能存储512MB的数据,String类型是二进制安全的,即可以存储任何数据、比如数字、图片、序列化对象等
1.2 set/get/append/strlen命令
#判断该键是否存在,存在返回1,否则返回0。
redis 127.0.0.1:6379> exists mykey
#该键并不存在,因此append命令返回当前Value的长度。
redis 127.0.0.1:6379> append mykey "Hello" #该键已经存在,因此返回追加后Value的长度。
redis 127.0.0.1:6379> append mykey " world" #通过get命令获取该键,以判断append的结果。
redis 127.0.0.1:6379> get mykey
#通过set命令为键设置新值,并覆盖原有值。
redis 127.0.0.1:6379> set mykey "this is a test" redis 127.0.0.1:6379> get mykey
"this is a test"#获取指定Key的字符长度。
redis 127.0.0.1:6379> strlen mykey
1.3 incr/decr/incrby/decrby 命令
#设置Key的值为20
redis 127.0.0.1:6379> set mykey 20 #该Key的值递增1
redis 127.0.0.1:6379> incr mykey#该Key的值递减1
redis 127.0.0.1:6379> decr mykey#删除已有键。
redis 127.0.0.1:6379> del mykey
#对空值执行递减操作,其原值被设定为0,递减后的值为-1
redis 127.0.0.1:6379> decr mykeyredis 127.0.0.1:6379> del mykey
#对空值执行递增操作,其原值被设定为0,递增后的值为1
redis 127.0.0.1:6379> incr mykey
(integer) 1
redis 127.0.0.1:6379> set mykey hello
#将该键的Value设置为不能转换为整型的普通字符串。redis 127.0.0.1:6379> incr mykey
redis 127.0.0.1:6379> set mykey 10#减少指定的整数
redis 127.0.0.1:6379> decrby mykey 5 #增加指定的整数
redis 127.0.0.1:6379> incrby mykey 10
1.4 getset命令
#将计数器的值原子性的递增1
redis 127.0.0.1:6379> incr mycounter #在获取计数器原有值的同时,并将其设置为新值,这两个操作原子性的同时完成。
redis 127.0.0.1:6379> getset mycounter 0 #查看设置后的结果。
redis 127.0.0.1:6379> get mycounter
1.5 setex命令
#设置指定Key的过期时间为10秒
redis 127.0.0.1:6379> setex mykey 15 "hello" #通过ttl命令查看一下指定Key的剩余存活时间(秒数),-2表示已经过期,-1表示永不过期。
redis 127.0.0.1:6379> ttl mykey #在该键的存活期内我们仍然可以获取到它的Value。
redis 127.0.0.1:6379> get mykey
redis 127.0.0.1:6379> ttl mykey #获取已过期的Key将返回nil。
redis 127.0.0.1:6379> get mykey
1.6 setnx命令
#删除该键,以便于下面的测试验证。
redis 127.0.0.1:6379> del mykey #该键并不存在,因此setnx命令执行成功
redis 127.0.0.1:6379> setnx mykey "hello" #该键已经存在,因此本次设置没有产生任何效果
redis 127.0.0.1:6379> setnx mykey "world" #从结果可以看出,返回的值仍为第一次设置的值
redis 127.0.0.1:6379> get mykey
1.7 mset/mget/msetnx命令
#批量设置了key1和key2两个键。
redis 127.0.0.1:6379> mset key1 "hello" key2 "world" #批量获取了key1和key2两个键的值
redis 127.0.0.1:6379> mget key1 key2#批量设置key3和key4两个键,因为之前他们并不存在,所以msetnx命令执行成功并返回1。
redis 127.0.0.1:6379> msetnx key3 "zhang" key4 "san"
redis 127.0.0.1:6379> mget key3 key4#批量设置了key3和key5两个键,但是key3已经存在,所以msetnx命令执行失败并返回0。
redis 127.0.0.1:6379> msetnx key3 "hello" key5 "world" #批量获取key3和key5,由于key5没有设置成功,所以返回nil。
redis 127.0.0.1:6379> mget key3 key5
二、List数据类型
2.1 概述
列表的元素类型为string,按照插入顺序排序,在列表的头部或尾部添加元素
2.2 lpush/lpushx/lrange命令
redis 127.0.0.1:6379> del mykey
(integer) 1redis 127.0.0.1:6379> lpush mykey a b c d
#mykey键并不存在,该命令会创建该键及与其关联的List,之后在将参数中的values从左到右依次插入。
(integer) 4redis 127.0.0.1:6379> lrange mykey 0 2
#取从位置0开始到位置2结束的3个元素。
1) "d"
2) "c"
3) "b"redis 127.0.0.1:6379> lrange mykey 0 -1
#取链表中的全部元素,其中0表示第一个元素,-1表示最后一个元素。
1) "d"
2) "c"
3) "b"
4) "a"
redis 127.0.0.1:6379> lpushx mykey2 e
#mykey2键此时并不存在,因此lpushx命令将不会进行任何操作,其返回值为0。
(integer) 0redis 127.0.0.1:6379> lrange mykey2 0 -1
#可以看到mykey2没有关联任何List Value。
(empty list or set)
redis 127.0.0.1:6379> lpushx mykey e
#mykey键此时已经存在,所以lpushx命令插入成功,并返回链表中当前元素的数量。
(integer) 5redis 127.0.0.1:6379> lrange mykey 0 0
#获取该键的List Value的头部元素。
1) "e"
2.3 lpop/llen命令
redis 127.0.0.1:6379> del mykey
(integer) 1redis 127.0.0.1:6379> lpush mykey a b c d
(integer) 4redis 127.0.0.1:6379> lpop mykey
#移除并返回mykey键的第一个元素,从左取
"d"redis 127.0.0.1:6379> lpop mykey
"c"redis 127.0.0.1:6379> llen mykey
#在执行lpop命令两次后,链表头部的两个元素已经被弹出,此时链表中元素的数量是2
(integer) 2
2.4 lrem/lset/lindex/ltrim命令
redis 127.0.0.1:6379> del mykey
(integer) 1redis 127.0.0.1:6379> lpush mykey a b c d a c
#为后面的示例准备测试数据。
(integer) 6redis 127.0.0.1:6379> lrem mykey 2 a
#从头部(left)向尾部(right)变量链表,删除2个值等于a的元素,返回值为实际删除的数量。
(integer) 2redis 127.0.0.1:6379> lrange mykey 0 -1
#看出删除后链表中的全部元素。
1) "c"
2) "d"
3) "c"
4) "b"
redis 127.0.0.1:6379> lindex mykey 1
#获取索引值为1(头部的第二个元素)的元素值。
"d"
redis 127.0.0.1:6379> lset mykey 1 e
#将索引值为1(头部的第二个元素)的元素值设置为新值e。
OK
redis 127.0.0.1:6379> lindex mykey 1
#查看是否设置成功。
"e"redis 127.0.0.1:6379> lindex mykey 6
#索引值6超过了链表中元素的数量,该命令返回nil。
(nil)
redis 127.0.0.1:6379> lset mykey 6 hh
#设置的索引值6超过了链表中元素的数量,设置失败,该命令返回错误信息。
(error) ERR index out of rangeredis 127.0.0.1:6379> ltrim mykey 0 2
#仅保留索引值0到2之间的3个元素,注意第0个和第2个元素均被保留。
OKredis 127.0.0.1:6379> lrange mykey 0 -1
#查看trim后的结果。
1) "c"
2) "e"
3) "c"
2.5 linsert命令
redis 127.0.0.1:6379> del mykey
#删除该键便于后面的测试。
(integer) 1redis 127.0.0.1:6379> lpush mykey a b c d e
#为后面的示例准备测试数据。
(integer) 5redis 127.0.0.1:6379> linsert mykey before a a1
#在a的前面插入新元素a1。
(integer) 6。redis 127.0.0.1:6379> lrange mykey 0 -1
#查看是否插入成功,从结果看已经插入
1) "e"
2) "d"
3) "c"
4) "b"
5) "a1"
6) "a"
redis 127.0.0.1:6379> linsert mykey after e e2
#在e的后面插入新元素e2,从返回结果看已经插入成功。
(integer) 7redis 127.0.0.1:6379> lindex mykey 1
#再次查看是否插入成功。
"e2"
redis 127.0.0.1:6379> linsert mykey after k a
#在不存在的元素之前或之后插入新元素,linsert命令操作失败,并返回-1。
(integer) -1redis 127.0.0.1:6379> linsert mykey1 after a a2
#为不存在的Key插入新元素,linsert命令操作失败,返回0。
(integer) 0
2.6 rpush/rpushx/rpop/rpoplpush命令
redis 127.0.0.1:6379> del mykey
#删除该键,以便于后面的测试。
(integer) 1redis 127.0.0.1:6379> rpush mykey a b c d
#从链表的尾部插入参数中给出的values,插入顺序是从右到左依次插入。
(integer) 4redis 127.0.0.1:6379> lrange mykey 0 -1
#通过lrange命令可以获悉rpush在插入多值时的插入顺序。
1) "a"
2) "b"
3) "c"
4) "d"redis 127.0.0.1:6379> rpushx mykey e
#该键已经存在并且包含4个元素,rpushx命令将执行成功,并将元素e插入到链表的尾部。
(integer) 5redis 127.0.0.1:6379> lindex mykey 4
#通过lindex命令可以看出之前的rpushx命令确实执行成功,因为索引值为4的元素已经是新元素了。
"e"redis 127.0.0.1:6379> rpushx mykey2 e
#由于mykey2键并不存在,因此rpushx命令不会插入数据,其返回值为0。
(integer) 0redis 127.0.0.1:6379> lrange mykey 0 -1
#在执行rpoplpush命令前,先看一下mykey中链表的元素有哪些,注意他们的位置关系。
1) "a"
2) "b"
3) "c"
4) "d"
5) "e"127.0.0.1:6379> RPOP mykey
#移除并返回mykey键的第一个元素,从右取
"e"127.0.0.1:6379> LRANGE mykey 0 -1
1) "a"
2) "b"
3) "c"
4) "d"redis 127.0.0.1:6379> rpoplpush mykey mykey2
#将mykey的尾部元素e弹出,同时再插入到mykey2的头部(原子性的完成这两步操作)。
"d"redis 127.0.0.1:6379> lrange mykey 0 -1
#通过lrange命令查看mykey在弹出尾部元素后的结果。
1) "a"
2) "b"
3) "c"redis 127.0.0.1:6379> lrange mykey2 0 -1
#通过lrange命令查看mykey2在插入元素后的结果。
1) "d"redis 127.0.0.1:6379> rpoplpush mykey mykey
#将source和destination设为同一键,将mykey中的尾部元素移到其头部。
"c"redis 127.0.0.1:6379> lrange mykey 0 -1
#查看移动结果。
1) "c"
2) "a"
3) "b"
三、Hash数据类型(散列类型)
3.1 概述
hash用于存储对象。可以采用这样的命名方式:对象类别和ID构成键名,使用字段表示对象的属性,而字段值则存储属性值。 如:存储 ID 为 2 的汽车对象。
如果Hash中包含很少的字段,那么该类型的数据也将仅占用很少的磁盘空间。每一个Hash可以存储4294967295个键值对。
3.2 hset/hget/hdel/hexists/hlen/hsetnx命令
redis 127.0.0.1:6379> hset myhash field1 "zhang" #给键值为myhash的键设置字段为field1,值为zhang。
(integer) 1
redis 127.0.0.1:6379> hget myhash field1 #获取键值为myhash,字段为field1的值。
"zhang"
redis 127.0.0.1:6379> hget myhash field2 #myhash键中不存在field2字段,因此返回nil。
(nil)
redis 127.0.0.1:6379> hset myhash field2 "san" #给myhash添加一个新的字段field2,其值为san。
(integer) 1
redis 127.0.0.1:6379> hlen myhash #hlen命令获取myhash键的字段数量。
(integer) 2
redis 127.0.0.1:6379> hexists myhash field1 #判断myhash键中是否存在字段名为field1的字段,由于存在,返回值为1。
(integer) 1
redis 127.0.0.1:6379> hdel myhash field1 #删除myhash键中字段名为field1的字段,删除成功返回1。
(integer) 1
redis 127.0.0.1:6379> hdel myhash field1 #再次删除myhash键中字段名为field1的字段,由于上一条命令已经将其删除,因为没有删除,返回0。
(integer) 0
redis 127.0.0.1:6379> hexists myhash field1 #判断myhash键中是否存在field1字段,由于上一条命令已经将其删除,因为返回0。
(integer) 0
redis 127.0.0.1:6379> hsetnx myhash field1 zhang #通过hsetnx命令给myhash添加新字段field1,其值为zhang,因为该字段已经被删除,所以该命令添加成功并返回1。
(integer) 1
redis 127.0.0.1:6379> hsetnx myhash field1 zhang #由于myhash的field1字段已经通过上一条命令添加成功,因为本条命令不做任何操作后返回0。
(integer) 0
3.3 hincrby命令
redis 127.0.0.1:6379> del myhash
#删除该键,便于后面示例的测试。
(integer) 1redis 127.0.0.1:6379> hset myhash field 5
#准备测试数据,该myhash的field字段设定值5。
(integer) 1redis 127.0.0.1:6379> hincrby myhash field 1
#hincrby命令给myhash的field字段的值加1,返回加后的结果。
(integer) 6redis 127.0.0.1:6379> hincrby myhash field -1 #hincrby命令给myhash的field字段的值加-1,返回加后的结果。
(integer) 5redis 127.0.0.1:6379> hincrby myhash field -10
#hincrby命令给myhash的field字段的值加-10,返回加后的结果。
(integer) -5
3.4 hgetall/hkeys/hvals/hmget/hmset 命令
redis 127.0.0.1:6379> del myhash
#删除该键,便于后面示例测试。
(integer) 1redis 127.0.0.1:6379> hmset myhash field1 "hello" field2 "world"
#hmset命令为该键myhash,一次性设置多个字段,分别是field1="hello", field2="world"。
OKredis 127.0.0.1:6379> hmget myhash field1 field2 field3 #hmget命令获取myhash键的多个字段,其中field3并不存在,因为在返回结果中与该字段对应的值为nil。
1) "hello"
2) "world"
3) (nil)redis 127.0.0.1:6379> hgetall myhash
#hgetall命令返回myhash键的所有字段及其值,从结果中可以看出,他们是逐对列出的。
1) "field1"
2) "hello"
3) "field2"
4) "world"redis 127.0.0.1:6379> hkeys myhash
#hkeys命令仅获取myhash键中所有字段的名字。
1) "field1"
2) "field2"redis 127.0.0.1:6379> hvals myhash
#hvals命令仅获取myhash键中所有字段的值。
1) "hello"
2) "world"
四、Set数据类型(无序集合)
4.1 概述
无序集合,元素类型为String类型,元素具有唯一性,不允许存在重复的成员。多个集合类型之间可以进行并集、交集和差集运算。
4.2 应用范围
- 可以使用Redis的Set数据类型跟踪一些唯一性数据,比如访问某一博客的唯一IP地址信息。
对于此场景,我们仅需在每次访问该博客时将访问者的IP存入Redis中,Set数据类型会自动保证IP地址的唯一性。 - 充分利用Set类型的服务端聚合操作方便、高效的特性,可以用于维护数据对象之间的关联关系。
比如所有购买某一电子设备的客户ID被存储在一个指定的Set中,而购买另外一种电子产品的客户ID被存储在另外一个Set中,
如果此时我们想获取有哪些客户同时购买了这两种商品时,Set的intersections命令就可以充分发挥它的方便和效率的优势了。
4.3 sadd/smembers/scard/sismember命令
redis 127.0.0.1:6379> sadd myset a b c
#插入测试数据,由于该键myset之前并不存在,因此参数中的三个成员都被正常插入。
(integer) 3redis 127.0.0.1:6379> sadd myset a d e
#由于参数中的a在myset中已经存在,因此本次操作仅仅插入了d和e两个新成员。
(integer) 2redis 127.0.0.1:6379> sismember myset a
#判断a是否已经存在,返回值为1表示存在。
(integer) 1redis 127.0.0.1:6379> sismember myset f
#判断f是否已经存在,返回值为0表示不存在。
(integer) 0redis 127.0.0.1:6379> smembers myset
#通过smembers命令查看插入的结果,从结果可以看出,输出的顺序和插入顺序无关。
1) "c"
2) "d"
3) "a"
4) "b"
5) "e"redis 127.0.0.1:6379> scard myset
#获取Set集合中元素的数量。
(integer) 5
4.4 spop/srem/srandmember/smove 命令
redis 127.0.0.1:6379> del myset #删除该键,便于后面的测试。
(integer) 1redis 127.0.0.1:6379> sadd myset a b c d
#为后面的示例准备测试数据。
(integer) 4redis 127.0.0.1:6379> smembers myset
#查看Set中成员的位置。
1) "c"
2) "d"
3) "a"
4) "b"redis 127.0.0.1:6379> srandmember myset
#从结果可以看出,该命令确实是随机的返回了某一成员。
"c"redis 127.0.0.1:6379> spop mysey
#随机的移除并返回Set中的某一成员。
"b"redis 127.0.0.1:6379> smembers myset
#查看移出后Set的成员信息。
1) "c"
2) "d"
3) "a"redis 127.0.0.1:6379> srem myset a d f
#从Set中移出a、d和f三个成员,其中f并不存在,因此只有a和d两个成员被移出,返回为2。
(integer) 2redis 127.0.0.1:6379> smembers myset
#查看移出后的输出结果。
1) "c"redis 127.0.0.1:6379> sadd myset a b
#为后面的smove命令准备数据。
(integer) 2redis 127.0.0.1:6379> sadd myset2 c d
(integer) 2redis 127.0.0.1:6379> smove myset myset2 a
#将a从myset移到myset2,从结果可以看出移动成功。
(integer) 1redis 127.0.0.1:6379> smove myset myset2 a
#再次将a从myset移到myset2,由于此时a已经不是myset的成员了,因此移动失败并返回0。
(integer) 0redis 127.0.0.1:6379> smembers myset
#分别查看myset和myset2的成员,确认移动是否真的成功。
1) "b"
redis 127.0.0.1:6379> smembers myset2
1) "c"
2) "d"
3) "a"
五、Sorted Set数据类型(zset、有序集合)
5.1 概述
a、有序集合,元素类型为Sting,元素具有唯一性,不能重复。
b、每个元素都会关联一个double类型的分数score(表示权重),可以通过权重的大小排序,元素的score可以相同。
5.2 应用范围
1)可以用于一个大型在线游戏的积分排行榜。
每当玩家的分数发生变化时,可以执行ZADD命令更新玩家的分数,此后再通过ZRANGE命令获取积分TOP10的用户信息。
当然我们也可以利用ZRANK命令通过username来获取玩家的排行信息。
最后我们将组合使用ZRANGE和ZRANK命令快速的获取和某个玩家积分相近的其他用户的信息。
2)Sorted-Set类型还可用于构建索引数据。
5.3 zadd/zcard/zcount/zrem/zincrby/zscore/zrange/zrank命令
redis 127.0.0.1:6379> zadd myzset 1 "one" #添加一个分数为1的成员。
(integer) 1
redis 127.0.0.1:6379> zadd myzset 2 "two" 3 "three" #添加两个分数分别是2和3的两个成员。
(integer) 2
redis 127.0.0.1:6379> zrange myzset 0 -1 WITHSCORES #0表示第一个成员,-1表示最后一个成员。WITHSCORES选项表示返回的结果中包含每个成员及其分数,否则只返回成员。
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
redis 127.0.0.1:6379> zrank myzset one #获取成员one在Sorted-Set中的位置索引值。0表示第一个位置。
(integer) 0
redis 127.0.0.1:6379> zrank myzset four #成员four并不存在,因此返回nil。
(nil)
redis 127.0.0.1:6379> zcard myzset #获取myzset键中成员的数量。
(integer) 3
redis 127.0.0.1:6379> zcount myzset 1 2 #zcount key min max,分数满足表达式1 <= score <= 2的成员的数量。
(integer) 2
redis 127.0.0.1:6379> zrem myzset one two #删除成员one和two,返回实际删除成员的数量。
(integer) 2
redis 127.0.0.1:6379> zcard myzset #查看是否删除成功。
(integer) 1
redis 127.0.0.1:6379> zscore myzset three #获取成员three的分数。返回值是字符串形式。
"3"
redis 127.0.0.1:6379> zscore myzset two #由于成员two已经被删除,所以该命令返回nil。
(nil)
redis 127.0.0.1:6379> zincrby myzset 2 one #成员one不存在,zincrby命令将添加该成员并假设其初始分数为0,将成员one的分数增加2,并返回该成员更新后的分数。
"2"
redis 127.0.0.1:6379> zincrby myzset -1 one #将成员one的分数增加-1,并返回该成员更新后的分数。
"1"
redis 127.0.0.1:6379> zrange myzset 0 -1 WITHSCORES #查看在更新了成员的分数后是否正确。
1) "one"
2) "1"
3) "three"
4) "3"
5.4 zrangebyscore/zremrangebyrank/zremrangebyscore命令
redis 127.0.0.1:6379> del myzset
(integer) 1
redis 127.0.0.1:6379> zadd myzset 1 one 2 two 3 three 4 four
(integer) 4
redis 127.0.0.1:6379> zrangebyscore myzset 1 2 #zrangebyscore key min max,获取分数满足表达式1 <= score <= 2的成员。
1) "one"
2) "two"
redis 127.0.0.1:6379> zrangebyscore myzset (1 2 #获取分数满足表达式1 < score <= 2的成员。
1) "two"
redis 127.0.0.1:6379> zrangebyscore myzset -inf +inf limit 2 3 #-inf表示第一个成员(位置索引值最低的,即0),+inf表示最后一个成员(位置索引值最高的),limit后面的参数用于限制返回成员的值,2表示从位置索引等于2的成员开始,取后面3个成员。
1) "three"
2) "four"
redis 127.0.0.1:6379> zrangebyscore myzset 0 4 limit 2 3redis 127.0.0.1:6379> zremrangebyscore myzset 1 2 #删除分数满足表达式1 <= score <= 2的成员,并返回实际删除的数量。
(integer) 2
redis 127.0.0.1:6379> zrange myzset 0 -1 #看出一下上面的删除是否成功。
1) "three"
2) "four"
redis 127.0.0.1:6379> zremrangebyrank myzset 0 1 #删除位置索引满足表达式0 <= rank <= 1的成员。
(integer) 2
redis 127.0.0.1:6379> zcard myzset #查看上一条命令是否删除成功。
(integer) 0
5.5 zrevrange/zrevrangebyscore/zrevrank命令
redis 127.0.0.1:6379> del myzset #为后面的示例准备测试数据。
(integer) 0
redis 127.0.0.1:6379> zadd myzset 1 one 2 two 3 three 4 four
(integer) 4
redis 127.0.0.1:6379> zrevrange myzset 0 -1 WITHSCORES #以位置索引从高到低的方式获取并返回此区间内的成员。
1) "four"
2) "4"
3) "three"
4) "3"
5) "two"
6) "2"
7) "one"
8) "1"
redis 127.0.0.1:6379> zrevrange myzset 1 3 #由于是从高到低的排序,所以位置等于0的是four,1是three,并以此类推。
1) "three"
2) "two"
3) "one"
redis 127.0.0.1:6379> zrevrank myzset one #由于是从高到低的排序,所以one的位置是3。
(integer) 3
redis 127.0.0.1:6379> zrevrank myzset four #由于是从高到低的排序,所以four的位置是0。
(integer) 0
redis 127.0.0.1:6379> zrevrangebyscore myzset 3 0 #zrevrangebyscore key max min, 获取分数满足表达式3 >= score >= 0 的成员,并以从高到底的顺序输出。
1) "three"
2) "two"
3) "one"
redis 127.0.0.1:6379> zrevrangebyscore myzset 4 0 limit 1 2 #zrevrangebyscore命令支持limit选项,其含义等同于zrangebyscore中的该选项,只是在计算位置时按照相反的顺序计算和获取。
1) "three"
2) "two"
192.168.80.10:6379> zrevrangebyscore myzset +inf -inf limit 1 3
相关文章:
Redis各数据类型特定的命令和用法 1.0版本
目录 一、Sring数据类型1.1 概述1.2 set/get/append/strlen命令1.3 incr/decr/incrby/decrby 命令1.4 getset命令1.5 setex命令1.6 setnx命令1.7 mset/mget/msetnx命令 二、List数据类型2.1 概述2.2 lpush/lpushx/lrange命令2.3 lpop/llen命令2.4 lrem/lset/lindex/ltrim命令2.…...
卫星图像应用 - 洪水检测 使用DALI进行数据预处理
这篇文章是上一篇的延申。 运行环境:Google Colab 1. 当今的深度学习应用包含由许多串行运算组成的、复杂的多阶段数据处理流水线,仅依靠 CPU 处理这些流水线已成为限制性能和可扩展性的瓶颈。 2. DALI 是一个用于加载和预处理数据的库,可…...
为什么字节大量用GO而不是Java?
见字如面,我是军哥。 我看很多程序员对字节编程语言选型很好奇,为此我还特地问了在字节的两位4-1的技术大佬朋友,然后加上自己的思考,总结了一下就以下 2 个原因: 1、 选型上没有历史包袱 字节的早期的程序员大多来自于…...
Hive SQL初级练习(30题)
前言 Hive 的重要性不必多说,离线批处理的王者,Hive 用来做数据分析,SQL 基础必须十分牢固。 环境准备 建表语句 这里建4张表,下面的练习题都用这些数据。 -- 创建学生表 create table if not exists student_info(stu_id st…...
NSSCTF做题(6)
[HCTF 2018]Warmup 查看源代码得到 开始代码审计 <?php highlight_file(__FILE__); class emmm { public static function checkFile(&$page) { $whitelist ["source">"source.php","hint"…...
公众号商城小程序的作用是什么
公众号是微信平台重要的生态体系之一,它可以与其它体系连接实现多种效果,同时公众号内容创作者非常多,个人或企业商家等,会通过公众号分享信息或获得收益等,而当商家需要在微信做私域经营或想要转化粉丝、售卖产品时就…...
关于 FOCA
目录 注意团队成员成品官网项目社区 版本信息致谢 注意 此文章会随时更新,最好收藏起来,总对你有好处。我们不定时发布一些 IT 内容,所以请关注我们。 此账号为 FOCA 唯一的官方账号,请勿轻易相信其他账号所发布内容。 团队 全…...
TVP专家谈腾讯云 Cloud Studio:开启云端开发新篇章
导语 | 近日,由腾讯云 TVP 团队倾力打造的 TVP 吐槽大会第六期「腾讯云 Cloud Studio」专场圆满落幕,6 位资深的 TVP 专家深度体验腾讯云 Cloud Studio 产品,提出了直击痛点的意见与建议,同时也充分肯定了腾讯云 Cloud Studio 的实…...
2023-09-27 Cmake 编译 OpenCV+Contrib 源码通用设置
Cmake 编译 OpenCV 通用设置 特点: 包括 Contrib 模块关闭了 Example、Test、OpenCV_AppLinux、Windows 均只生成 OpenCV_World 需要注意: 每次把 Cmake 缓存清空,否则,Install 路径可能被设置为默认路径Windows 需要注意编译…...
ACGAN
CGAN通过在生成器和判别器中均使用标签信息进行训练,不仅能产生特定标签的数据,还能够提高生成数据的质量;SGAN(Semi-Supervised GAN)通过使判别器/分类器重建标签信息来提高生成数据的质量。既然这两种思路都可以提高生成数据的质…...
模块化CSS
1、什么是模块化CSS 模块化CSS是一种将CSS样式表的规则和样式定义封装到模块或组件级别的方法,以便于更好地管理、维护和组织样式代码。这种方法通过将样式与特定的HTML元素或组件相关联,提供了一种更具可维护性、可复用性和隔离性的方式来处理样式。简单…...
意大利储能公司【Energy Dome】完成1500万欧元融资
来源:猛兽财经 作者:猛兽财经 猛兽财经获悉,总部位于意大利米兰的储能公司Energy Dome今日宣布已完成1500万欧元B轮融资。 本轮融资完成后,Energy Dome的融资总额已经达到了5500万欧元,本轮融资的参与者包括阿曼创新发…...
【Java 进阶篇】JDBC Connection详解:连接到数据库的关键
在Java中,要与数据库进行交互,需要使用Java数据库连接(JDBC)。JDBC允许您连接到不同类型的数据库,并执行SQL查询、插入、更新和删除操作。在JDBC中,连接数据库是一个重要的步骤,而Connection对象…...
vue-cli项目打包体积太大,服务器网速也拉胯(100kb/s),客户打开网站需要等十几秒!!! 尝试cdn优化方案
一、首先用插件webpack-bundle-analyzer查看自己各个包的体积 插件用法参考之前博客 vue-cli项目中,使用webpack-bundle-analyzer进行模块分析,查看各个模块的体积,方便后期代码优化 二、发现有几个插件体积较大,有改成CDN引用的…...
【优秀学员统计】python实现-附ChatGPT解析
1.题目 优秀学员统计 知识点排序统计编程基础 时间限制: 1s 空间限制: 256MB 限定语言:不限 题目描述: 公司某部门软件教导团正在组织新员工每日打卡学习活动,他们开展这项学习活动已经一个月了,所以想统计下这个月优秀的打卡员工。每个员工会对应一个id,每天的打卡记录记录…...
餐饮外卖配送小程序商城的作用是什么?
餐饮是支撑市场的主要行业之一,其市场规模很大,从业商家从大到小不计其数,对众商家来说,无论门店大小都希望不断生意增长,但在实际发展中却会面对不少痛点; 餐饮很适合线上经营,无论第三方外卖…...
【QT】使用toBase64方法将.txt文件的明文变为非明文(类似加密)
目录 0.环境 1.背景 2.详细代码 2.1 .h主要代码 2.2 .cpp主要代码,主要实现上述的四个方法 0.环境 windows 11 64位 Qt Creator 4.13.1 1.背景 项目需求:我们项目中有配置文件(类似.txt,但不是这个格式,本文以…...
《QDebug 2023年9月》
一、Qt Widgets 问题交流 1.Qt 程序在 Windows 上以管理员权限运行时无法响应拖放(Drop) 无论是 Widget 还是 QML 程序,以管理员权限运行时,都无法响应拖放操作。可以右键管理员权限打开 Qt Creator,然后丢个文本文件…...
C++使用高斯模糊处理图像
C使用高斯模糊处理图像 cv::GaussianBlur 是 OpenCV 中用于对图像进行高斯模糊处理的函数。高斯模糊是一种常用的图像滤波方法,它可以减少图像中的噪声,并平滑图像以降低细节级别。 void cv::GaussianBlur(const cv::Mat& src, cv::Mat& dst, …...
多维时序 | MATLAB实现PSO-BP多变量时间序列预测(粒子群优化BP神经网络)
多维时序 | MATLAB实现PSO-BP多变量时间序列预测(粒子群优化BP神经网络) 目录 多维时序 | MATLAB实现PSO-BP多变量时间序列预测(粒子群优化BP神经网络)效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现PSO-BP粒子群优化BP神经网络多变量时间序列预测ÿ…...
LeetCode 283. 移动零
移动零 问题描述 LeetCode 283. 移动零 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意,必须在不复制数组的情况下原地对数组进行操作。 解决思路 为了将所有 0 移动到数组的末尾&#…...
【数据结构】选择排序 堆排序(二)
目录 一,选择排序 1,基本思想 2, 基本思路 3,思路实现 二,堆排序 1,直接选择排序的特性总结: 2,思路实现 3,源代码 最后祝大家国庆快乐! 一…...
opencv实现目标跟踪及视频转存
创建跟踪器 def createTypeTracker(trackerType): 读取视频第一帧,选择跟踪的目标 读第一帧。 ok, frame video.read() 选择边界框 bbox cv2.selectROI(frame, False) 初始化跟踪器 tracker_type ‘MIL’ tracker createTypeTracker(tracker_type) 用第一…...
R | R及Rstudio安装、运行环境变量及RStudio配置
R | R及Rstudio安装、运行环境变量及RStudio配置 一、介绍1.1 R介绍1.2 RStudio介绍 二、R安装2.1 演示电脑系统2.2 R下载2.3 R安装2.4 R语言运行环境设置(环境变量)2.4.1 目的2.4.2 R-CMD测试2.4.3 设置环境变量 2.5 R安装测试 三、RStudio安装3.1 RStu…...
智能回答机器人的“智能”体现在哪里?
人工智能的广泛应用已经成为当今社会科技发展的趋势之一。通过人工智能技术,我们可以在不同领域中实现自动化、智能化和高效化,从而大大提升生产和生活效率。智能回答机器人的出现和使用便能很好的证明这一点。今天我们就来探讨一下智能会打机器人的“智…...
多网卡场景数据包接收时ip匹配规则
多网卡场景数据包接收时ip匹配规则 mac地址匹配规则 接收数据包时数据包中的目的mac地址匹配接收网卡的mac地址后,数据包才会继续被传递到网络层处理 ip地址匹配规则 图1: 参见:https://zhuanlan.zhihu.com/p/529160026?utm_id0 图2&am…...
安防视频平台EasyCVR视频调阅全屏播放显示异常是什么原因?
安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…...
1.5.C++项目:仿muduo库实现并发服务器之socket模块的设计
项目完整版在: 一、socket模块:套接字模块 二、提供的功能 Socket模块是对套接字操作封装的一个模块,主要实现的socket的各项操作。 socket 模块:套接字的功能 创建套接字 绑定地址信息 开始监听 向服务器发起连接 获取新连接 …...
whisper+剪映+chatgpt实现实时语音对话功能
whisper将录音文件转成文字---chatgpt回答---剪映tts将文字转成语言。 GitHub - openai/whisper: Robust Speech Recognition via Large-Scale Weak Supervision whisper剪映chatgpt实现实时语音对话功能_哔哩哔哩_bilibili...
ASUS华硕ZenBook 13灵耀U 2代U3300F笔记本UX333FN/FA原装出厂Win10系统工厂安装模式
系统自带所有驱动、出厂主题壁纸、系统属性华硕专属LOGO标志、Office办公软件、MyASUS华硕电脑管家等预装程序 下载链接:https://pan.baidu.com/s/1dK0vMZMECPlT63Rb6-jeFg?pwdbym5 所需要工具:16G或以上的U盘(非必需) 文件格式:HDI,SWP,O…...
wordpress广告位插件/肇庆seo排名
在创建SpringBoot项目时,勾选Spring Security依赖,会在Maven中导入Spring Security。org.springframework.boot spring-boot-starter-security这个依赖中有一个登陆拦截器,SpringBoot项目访问任意接口(页面)都跳转到login登录页面这是Spring…...
wordpress插件聊天室小人/郑州seo推广优化
红色来源于山脉,象征着狂躁、愤怒、混乱,血雨腥风,电光火石。蓝色来源于海岛,象征着控制、幻觉、诡计,运筹帷幄,谋定后动。绿色来源于树林,象征着生命、蛮力、成长,横冲直撞…...
制作网页和做网站是一个意思吗/网站查询服务器
本文欢迎转载,转载请注明出处和作者。由于各种监控系统的实时告警,都需要使用邮箱进行发送,而其中使用SMTP协议的邮箱,各种监控系统、ITSM系统等支持最广泛。为测试监控系统的告警功能,需要先搭建1个SMTP邮箱。实验环境…...
做推广的网站带宽需要多少钱/关键词优化精灵
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。 示例: 给定一个链表: 1->2->3->4->5, 和 n 2. 当删除了倒数第二个节点后,链表变为 1->2->3->5. 说明: 给定的 n 保证是有效…...
电子商务知名网站/关键词整站优化
其实应该是两个神奇的工具一个是脑图,也叫思维导图,对于像我这样收不住思维的人再合适不过了而另一个就是他的得力工具FreeMind,还是开源的。文章来源:http://herald.seu.edu.cn/blog/shiningray/archive/2005/06/08/20613.aspx转载于:https:…...
杭州的做网站公司/培训心得体会1500字
以此来记录我个人的学习历程!~~转载于:https://www.cnblogs.com/Gogo-ouchen/p/4623185.html...