文章目录

知识点07:String类型的常用命令知识点08:Hash类型的常用命令知识点09:List类型的常用命令知识点10:Set类型的常用命令知识点11:Zset类型的常用命令知识点12:BitMap类型的常用命令知识点13:HyperLogLog类型的常用命令后记

知识点07:String类型的常用命令

目标:掌握String类型的常用命令 实施

set:给String类型的Value的进行赋值或者更新

语法:set K V get:读取String类型的Value的值

语法:get K mset:用于批量写多个String类型的KV

语法:mset K1 V1 K2 V2 …… mget:用于批量读取String类型的Value

语法:mget K1 K2 K3 …… setnx:只能用于新增数据,当K不存在时可以进行新增

语法:setnx K V应用:构建抢占锁,搭配expire来使用 incr:用于对数值类型的字符串进行递增,递增1,一般用于做计数器

语法:incr K incrby:指定对数值类型的字符串增长固定的步长

语法:incrby K N decr:对数值类型的数据进行递减,递减1

语法:decr K decrby:按照指定步长进行递减

语法:decrby K N incrbyfloat:基于浮点数递增

语法:incrbyfloat K N strlen:统计字符串的长度

语法:strlen K getrange:用于截取字符串

语法:getrange s2 start end node1:6379> keys *

(empty list or set)

node1:6379> set s1 hadoop

OK

node1:6379> get s1

"hadoop"

node1:6379> mset s2 hive s3 spark

OK

node1:6379> keys *

1) "s3"

2) "s1"

3) "s2"

node1:6379> mget s1 s3

1) "hadoop"

2) "spark"

node1:6379> set s1 oozie

OK

node1:6379> get s1

"oozie"

node1:6379>

node1:6379> setnx s4 hue

(integer) 1

node1:6379> get s4

"hue"

node1:6379> setnx s4 flume

(integer) 0

node1:6379> get s4

"hue"

node1:6379> set s5 2

OK

node1:6379> get s5

"2"

node1:6379> incr s5

(integer) 3

node1:6379> get s5

"3"

node1:6379> incr s5

(integer) 4

node1:6379> get s5

"4"

node1:6379> incrby s5 3

(integer) 7

node1:6379> get s5

"7"

node1:6379> decr s5

(integer) 6

node1:6379> get s5

"6"

node1:6379> decrby s5 2

(integer) 4

node1:6379> get s5

"4"

node1:6379> set s6 19.2

OK

node1:6379> get s6

"19.2"

node1:6379> incrbyfloat s6 2.5

"21.7"

node1:6379> get s6

"21.7"

node1:6379> get s1

"oozie"

node1:6379> strlen s1

(integer) 5

node1:6379> getrange s1 0 2

"ooz"

node1:6379> getrange s1 2 2

"z"

node1:6379>

小结

掌握String类型的常用命令

知识点08:Hash类型的常用命令

目标:掌握Hash类型的常用命令 实施

hset:用于为某个K添加一个属性

语法:hset K k v hget:用于获取某个K的某个属性的值

语法:hget K k hmset:批量的为某个K赋予新的属性

语法:hmset K k1 v1 k2 v2 …… hmget:批量的获取某个K的多个属性的值

语法:hmget K k1 k2 k3…… hgetall:获取所有属性的值

语法:hgetall K hdel:删除某个属性

语法:hdel K k1 k2 …… hlen:统计K对应的Value总的属性的个数

语法:hlen K hexists:判断这个K的V中是否包含这个属性

语法:hexists K k hvals:获取所有属性的value的

语法:hvals K node1:6379> hget m1 name

"zhangsan"

node1:6379> hget m1 age

"19"

node1:6379> hmset m1 gender male phone 110 addr shanghai

OK

node1:6379> hmget m1 name phone gender

1) "zhangsan"

2) "110"

3) "male"

node1:6379> hgetall m1

1) "name"

2) "zhangsan"

3) "age"

4) "19"

5) "gender"

6) "male"

7) "phone"

8) "110"

9) "addr"

10) "shanghai"

node1:6379> hdel m1 gender

(integer) 1

node1:6379> hgetall m1

1) "name"

2) "zhangsan"

3) "age"

4) "19"

5) "phone"

6) "110"

7) "addr"

8) "shanghai"

node1:6379> hlen m1

(integer) 4

node1:6379> hexists m1 name

(integer) 1

node1:6379> hexists m1 gender

(integer) 0

node1:6379> hgetall m1

1) "name"

2) "zhangsan"

3) "age"

4) "19"

5) "phone"

6) "110"

7) "addr"

8) "shanghai"

node1:6379> hvals m1

1) "zhangsan"

2) "19"

3) "110"

4) "shanghai"

小结

掌握Hash类型的常用命令

知识点09:List类型的常用命令

目标:掌握List类型的常用命令 实施

lpush:将每个元素放到集合的左边,左序放入

语法:lpush K e1 e2 e3…… rpush:将每个元素放到集合的右边,右序放入

语法:rpush K e1 e2 e3…… lrange:通过下标的范围来获取元素的数据

语法:lrange K start end 注意:从左往右的下标从0开始,从右往左的下标从-1开始,一定是从小的到大的下标 lrange K 0 -1:所有元素 **llen:**统计集合的长度 语法:llen K lpop:删除左边的一个元素

语法:lpop K rpop:删除右边的一个元素

语法:rpop K node1:6379> lpush list1 1 2 2 3

(integer) 4

node1:6379> rpush list1 4 5 6 6 7 8

(integer) 10

node1:6379> lrange list1 0 9

1) "3"

2) "2"

3) "2"

4) "1"

5) "4"

6) "5"

7) "6"

8) "6"

9) "7"

10) "8"

node1:6379> lrange list1 4 9

1) "4"

2) "5"

3) "6"

4) "6"

5) "7"

6) "8"

node1:6379> llen list1

(integer) 10

node1:6379> lrange list1 0 -1

1) "3"

2) "2"

3) "2"

4) "1"

5) "4"

6) "5"

7) "6"

8) "6"

9) "7"

10) "8"

node1:6379> lrange list1 0 -3

1) "3"

2) "2"

3) "2"

4) "1"

5) "4"

6) "5"

7) "6"

8) "6"

node1:6379> lrange list1 -3 -1

1) "6"

2) "7"

3) "8"

node1:6379> lpop list1

"3"

node1:6379> rpop list1

"8"

node1:6379> lrange list1 0 -1

1) "2"

2) "2"

3) "1"

4) "4"

5) "5"

6) "6"

7) "6"

8) "7"

node1:6379>

小结

掌握List类型的常用命令

知识点10:Set类型的常用命令

目标:掌握Set类型的常用命令 实施

sadd:用于添加元素到Set集合中

语法:sadd K e1 e2 e3 e4 e5…… smembers:用于查看Set集合的所有成员

语法:smembers K sismember:判断是否包含这个成员

语法:sismember K e1 srem:删除其中某个元素

语法:srem K e scard:统计集合长度

语法:scard K sunion:取两个集合的并集

语法:sunion K1 K2 sinter:取两个集合的交集

语法:sinter K1 K2

node1:6379> sadd set1 1 1 2 2 3 4 3 4

(integer) 4

node1:6379> smembers set1

1) "1"

2) "2"

3) "3"

4) "4"

node1:6379> scard set1

(integer) 4

node1:6379> sismember set1 1

(integer) 1

node1:6379> sismember set1 5

(integer) 0

node1:6379> srem set1 3

(integer) 1

node1:6379> smembers set1

1) "1"

2) "2"

3) "4"

node1:6379> sadd set2 1 3 6 9 8 9

(integer) 5

node1:6379> sunion set1 set2

1) "1"

2) "2"

3) "3"

4) "4"

5) "6"

6) "8"

7) "9"

node1:6379> sinter set1 set2

1) "1"

node1:6379>

小结

掌握Set类型的常用命令

知识点11:Zset类型的常用命令

目标:掌握Zset类型的常用命令 实施

zadd:用于添加元素到Zset集合中

语法:zadd K score1 k1 score2 k2 …… zrange:范围查询

语法:zrange K start end [withscores] zrevrange:倒序查询

语法:zrevrange K start end [withscores] zrem:移除一个元素

语法:zrem K k1 zcard:统计集合长度

语法:zcard K zscore:获取评分

语法:zscore K k node1:6379> zadd zset1 99.5 yingyu 30.7 shuxue 29.9 yuwen 100 shengwu 56.73 dili

(integer) 5

node1:6379> zrange zset1 0 -1

1) "yuwen"

2) "shuxue"

3) "dili"

4) "yingyu"

5) "shengwu"

node1:6379> zrevrange zset1 0 -1

1) "shengwu"

2) "yingyu"

3) "dili"

4) "shuxue"

5) "yuwen"

node1:6379> zrevrange zset1 0 -1 withscores

1) "shengwu"

2) "100"

3) "yingyu"

4) "99.5"

5) "dili"

6) "56.729999999999997"

7) "shuxue"

8) "30.699999999999999"

9) "yuwen"

10) "29.899999999999999"

node1:6379>

node1:6379> zrem zset1 yuwen

(integer) 1

node1:6379> zrevrange zset1 0 -1 withscores

1) "shengwu"

2) "100"

3) "yingyu"

4) "99.5"

5) "dili"

6) "56.729999999999997"

7) "shuxue"

8) "30.699999999999999"

node1:6379>

node1:6379> zcard zset1

(integer) 4

node1:6379> zscore zset1 shuxue

"30.699999999999999"

注意:Redis中不建议存储小数值,存在精度问题,建议转换为整形存储 小结

掌握Zset类型的常用命令

知识点12:BitMap类型的常用命令

目标:掌握BitMap类型的常用命令 实施

功能:通过一个String对象的存储空间,来构建位图,用每一位0和1来表示状态

Redis中一个String最大支持512M = 2^32次方,1字节 = 8位 使用时,可以指定每一位对应的值,要么为0,要么为1,默认全部为0 用下标来标记每一位,第一个位的下标为0 举例:统计UV

一个位图中包含很多位,可以用每一个位表示一个用户id 读取数据,发现一个用户id,就将这个用户id对应的那一位改为1 统计整个位图中所有1的个数,就得到了UV setbit:修改某一位的值

语法:setbit bit1 位置 0/1 setbit bit1 0 1

getbit:查看某一位的值

语法:getbit K 位置 getbit bit1 9

bitcount:用于统计位图中所有1的个数

语法:bitcount K [start end] bitcount bit1

#start和end表示的是字节:1 字节 = 8 位

bitcount bit1 0 10

bitop:用于位图的运算:and/or/not/xor

语法:bitop and/or/xor/not bitrs bit1 bit2 bitop and bit3 bit1 bit2

bitop or bit4 bit1 bit2

小结

掌握BitMap类型的常用命令

知识点13:HyperLogLog类型的常用命令

目标:掌握HyperLogLog类型的常用命令 实施

功能:类似于Set集合,用于实现数据的去重

区别:底层实现原理不一样 应用:适合于数据量比较庞大的情况下的使用,存在一定的误差率 pfadd:用于添加元素

语法:pfadd K e1 e2 e3…… pfadd pf1 userid1 userid1 userid2 userid3 userid4 userid3 userid4

pfadd pf2 userid1 userid2 userid2 userid5 userid6

pfcount:用于统计个数

语法:pfcount K pfcount pf1

pfmerge:用于实现集合合并

语法:pfmerge pfrs pf1 pf2…… pfmerge pf3 pf1 pf2

小结

掌握HyperLogLog类型的常用命令

后记

博客主页:https://manor.blog.csdn.net

欢迎点赞  收藏 ⭐留言  如有错误敬请指正! 本文由 Maynor 原创,首发于 CSDN博客 不能老盯着手机屏幕,要不时地抬起头,看看老板的位置⭐ 专栏持续更新,欢迎订阅:https://blog.csdn.net/xianyu120/category_12394313.html

好文链接

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: