基于内存的分布式NoSQL数据库Redis(三)常用命令

知识点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来表示状态

      image-20210520075811401

      • Redis中一个String最大支持512M = 2^32次方,1字节 = 8位

      • 使用时,可以指定每一位对应的值,要么为0,要么为1,默认全部为0

      • 用下标来标记每一位,第一个位的下标为0

      image-20210520075824978

    • 举例:统计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
        

        image-20210520080018074

  • 小结

    • 掌握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

相关推荐

  1. Redis基本数据类型及命令

    2023-12-05 17:06:01       36 阅读
  2. Redis 基本命令

    2023-12-05 17:06:01       9 阅读
  3. Redis 命令

    2023-12-05 17:06:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-05 17:06:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-05 17:06:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-05 17:06:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-05 17:06:01       20 阅读

热门阅读

  1. 暴力破解攻击与彩虹表攻击

    2023-12-05 17:06:01       37 阅读
  2. 4、单例模式(Singleton Pattern)

    2023-12-05 17:06:01       38 阅读
  3. mySql笔记

    2023-12-05 17:06:01       42 阅读
  4. Android : ViewModel_解决textView 横竖屏数据丢失

    2023-12-05 17:06:01       38 阅读
  5. 【Android】Window和WindowManager

    2023-12-05 17:06:01       41 阅读
  6. 好用的chatgpt工具用过这个比较快

    2023-12-05 17:06:01       44 阅读