zoukankan      html  css  js  c++  java
  • Redis key的操作、5种数据类型及其使用场景

    redis默认有16个数据库,第一个数据库是db0,第16个数据库是db15,使用下标指定要使用数据库。

    先连接到redis服务器,再选择某个数据库进行操作:

    ./redis-cli -h 192.168.1.7  #端口使用默认的6379
    select 0  #选择|切换数据库,不指定默认使用db0
    
    dbsize  #返回当前数据库中key的数量
    
    flushdb  #清空当前数据库
    flushall  #清空所有数据库

    可在redis.conf中设置redis的数据库个数:


    redis的数据类型及其使用场景

    redis是一个键值数据库,存储的数据都是键值对的形式,key都是string类型,value可以是以下5种类型:

    • string  字符串

      常用于缓存、限流、计数器、分布式锁、分布式session等等。

    • hash  哈希

      常用于存储对象,比如存储用户相关信息、存储商品信息等对象。

    • list  列表

      因为是有序的,常用于存储时间轴上的事件,比如生成历程报告:

      回顾你与qq一同走过的10年,xx年月日,你注册了qq号;xx年月日你发布了第一条说说,xx年月日凌晨5点半,你还在和xx聊天;

      学生的成绩变化,股市的变化、按评论时间加载的评论等等,随时间变化。

    • set  集合

      常用于存储无序的多个元素,比如这条说说、朋友圈的赞你的好友,文章标签,好友分组等

    • sorted set  有序集合

      也叫做zset。

      常用于排行榜,比如热搜、阅读排行榜、评论排行榜、精华、热销商品、金曲排行榜、最火热点、新闻热点等等。


    key的常用操作

    set name chy  #设置一个键值对,如果key已存在,则是修改对应的值
    setnx name "chy01" #多个后缀nx,name不存在才设置,若name已存在,则不作任何操作,可以保护原值不被覆盖。
    mset name "chy" age 22 #同时设置|修改多个键值对,key1 value1 key2 value2......

    get name #获取name的值,如果name不存在,返回nil
    mget name age #同时获取多个key的值


    getset name "chy1" #先获取name原来的值,再重新赋值



    type name  #查看key对应的值的数据类型


    rename name myname #重命名key。将name重命名为myname,如果myname已存在,会覆盖myname原来的值 
    renamenx name myname #多了nx,如果myname不存在,才执行重命名,并返回1;如果myname已存在,则不执行重命名,返回0


    randomkey #从当前数据库中随机返回一个key。返回的是key,不是value


    exists name  #检查指定的key是否存在,存在则返回1,不存在返回0
    del name#删除一个键值对,返回1。若指定的键(值对)不存在,返回0




    expire name 60  #设置某个键值对的过期时间(有效期),单位s。60s后name键值对过期,自动删除该键值对。比如说24h后删除此说说。

    pexpire name 60000 #多了前缀p,表示单位是ms

    expireat name 1232323232323 #多了后缀at,表示使用时间戳,单位依然是s,距离1970.01.01 00:00:00 1232323232323秒后过期
    pexpireat name 121212122323 #多了前缀p、后缀at,表示使用时间戳+单位ms,距离1970.01.01 00:00:00 121212122323毫秒后过期


    ttl name #查看name的过期时间,默认单位s。-2表示此key不存在、已过期、已被删除,-1表示此key未设置过期时间,永久有效。

    persist name #清除设置的过期时间。默认永不过期。



    setex name 60 "chy02" #设置|修改一个键值对,并设置过期时间。60s后过期,ex即expire。


    move name 1 #把name键值对移到db1,即键值对的剪切


    keys n* #使用正则表达式匹配key,返回所有以n开头的key,匹配的是key。
    keys * #获取所有的key


    dump name #序列化指定的键值对,返回序列化后的值

    
    
    
    

    string  字符串

    string是redis的基础数据类型。

    set name "chy" #双引、单引均可
    set age 20 #redis没有数值类型,值默认是字符串类型,引不引都行。习惯上,key不引,数值型的value不引,中英文、符号之类的引一下。


    strlen name  #返回字符串(值)长度

    append name "01" #若键值对已存在,在值的末尾添加字符串;若key不存在,自动新建(初始化为空串),再执行添加操作。返回操作后字符串(值)的长度


    incr age #值的自增。将age的值+1,并返回+1后的值。如果age不存在,会先新建(值初始化为0),再执行自增。常用于主键自增,比如订单编号。
    incrby age 5  #指定增量为5,即+5,增量只能是整数
    incrbyfloat age 5.0 #增量是浮点数。整数算是一种特殊的浮点数,所以整数也行。
    
    decr age  #值的自减
    decrby age  5  #指定减量,即-5




    getrange name 0 2 #返回value的[0,2]区间上的字符串。redis的区间都是闭区间,都支持负数索引
    getrange name 0 -1 #支持负数索引

    hash  哈希

    hash也叫做散列,一个hash可储存多个键值对,hash中的键值对不叫作键值对,而是叫做字段。一个 hash 可以存储 232 - 1(42亿+)个字段。

     hash中字段值必须是字符串类型。

    hset user name "chy"  #在user中添加|更新name字段,如果user不存在,会自动创建。若之前name不存在,添加name字段并返回1;若之前name存在,则更新其值,返回0
    hsetnx user name "chy" #多了后缀nx,如果name字段已存在,则不进行任何操作,可以保护name字段的原值不被覆盖
    hmset user name "chy" age 20 #同时添加|更新多个字段


    hget user name #获取单个字段的值
    hmget user name age #获取多个字段的值


    hgetall user #获取整个hash的所有字段(字段名+字段值)
    hkeys user #获取所有的字段名
    hvals user #获取所有的字段值


    hdel user name #删除一个字段。hdel返回删除的字段个数
    hdel user name age #删除多个字段


    hincrby user age 5 #字段值的自增,指定增量,+5
    hincrby user age -2 #负值表示字段值的自减,-2。没有hincr、hdecr、hdecrby命令

    hincrbyfloat user age 5.0 #用法同上,只不过支持浮点数
    hincrbyfloat user age -2.0 #


    hexists user name #判断某个字段是否存在,存在返回1,不存在返回0

    hlen user #获取字段数

    h即hash,m即multiple。

    user是一个hash,是redis的一个key,值是多个字段。

    hash适合储存对象、json数据,一个字段存储一个属性。


    list  列表

    list是有序集合,元素可以重复,但元素只能是字符串类型。一个list可以存储 232 - 1 (42亿+)。

    lpush users "zhangsan" "lisi" #在list的头部插入一个或多个元素,l即left。若users不存在,会先自动创建,再插入。先插入"zhangsan",再插入"lisi",每次都是在最前面插入,list第一个元素是lisi
    lpushx users "zhangsan" "lisi" #多了一个x,表示如果users不存在,不作任何操作,不会自动创建

    rpush users "wangwu" "zhaoliu" #在list的尾部插入一个或多个元素,r即right,每次都是在最后面插入,list的最后一个元素是zhaoliu
    rpushx users "wangwu" "zhaoliu" #多个一个x,表示如果users不存在,不作任何操作,不会自动创建




    lpop users #弹出list的第一个元素。弹出是指返回并删除一个元素。
    rpop users #弹出list的最后一个元素


    blpop users 60 #弹出列表的第一个元素,若list是空的,会阻塞等待60s,这60s内list内有了元素就弹出。60是超时时间。b即block,阻塞。
    brpop users 60 #最后一个元素



    rpoplpush list1 list2 #弹出list1的最后一个元素,并在list2的头部插入该元素。即把列表的最后一个元素剪切到另一个列表的开头。
    brpoplpush list1 list2 60 #设置超时时间



    llen users #返回list的长度(元素个数),第一个l即list

    lrange users 0 -1 #返回[0,-1]上的所有元素。redis的区间都是闭区间,都支持负数索引

    lindex users 1 #返回指定位置上元素,是查找、并不是删除。指定下标。

    lset users 1 "zhangwei" #修改指定位置上元素,该位置要已存在元素,才能修改,否则报错。



    lrem users 0 "zhangsan" #移除list中所有值为zhangsan的元素。0表示删除匹配到的所有元素
    lrem users 2 "zhangsan" #从前往后搜索,删除匹配到的前2个元素
    lrem users -2 "zhangsan" #从后往前搜索,删除匹配到的前2个元素。正负表示搜索方向,数值表示删除个数。


    ltrim users 1 3 #修剪list,只保留[1,3]上的元素,会删除其它元素


    linsert users before "zhangsan" "lisi" #从前往后搜索"zhangsan",在匹配的第一个"zhangsan"前面插入元素lisi"。若"zhangsan"不存在,不做任何操作,返回-1;若users不存在,不做任何操作,返回0
    lisert users after "zhangsan" "lisi" #
    从前往后搜索"zhangsan",在匹配的第一个"zhangsan"后面插入元素lisi"

     list适合存储有序的多个元素,比如评论(时间顺序)。

    lpush comments '{"id":1,"comment":"质量很好","date":12121212121212}'

    元素只能是字符串,可以把整个json数据作为字符串存储,但整个json必须加引号。

    比如回顾你与qq一同走过的10年,xx年月日,你注册了qq号;xx年月日你发布了第一条说说,xx年月日凌晨5点半,你还在和xx聊天;

    学生的成绩变化,股市的变化、按评论时间加载的评论等等。


    set  集合

    set是无序集合,元素不可重复,元素只能是字符串。一个set可以存储 232 - 1 (42亿+)个元素。

    sadd users "zhangsan" "lisi"  #向集合中添加一个或多个元素,若users不存在,会自动创建。若set中已有该元素,则不添加该元素,返回本次操作添加的元素个数
    srem users "zhangsan" "lisi" #删除set中的一个或多个元素,若set中没有该元素,自动跳过


    smembers users #返会set中的所有元素

    sismember users "zhangsan" #检测某个元素是否是users的成员,是返回1,不是返回0。s is member ,第一个s即set。

    scard users #返回set中的元素个数



    spop users #随机弹出一个元素。set是无序的,只能随机弹,不能指定弹出哪个元素


    srandmember users #随机返回一个元素。是返回,不是弹出,不会删除该元素
    srandmember users 3  #随机返回3个元素。随机返回一个元素,再从剩下的元素中随机返回一个,再从剩下的元素中随机返回一个,依此类推。就是说返回的元素各不相同。
    srandmember users -3 #负数表示每次都从整个集合中选,不是从剩下的里面选,即返回的元素可能有相同的。若数值大于集合的元素总数,则返回集合中的所有元素。



    smove set1 set2 "zhangsan" #把set1中的元素"zhangsan"剪切到set2中



    sinter set1 set2 set3 #返回这些集合的交集(共同元素)
    sinterstore destset set1 set2 set3 #多了后缀store,表示求交集,并把交集中的元素存储到集合destset中。返回的是交集中的元素个数


    sunion set1 set2 set3 #并集(合并到一起)
    sunionstore destset set1 set2 set3


    sdiff set1 set2 #求差集(set1中有、set2中没有的元素)
    sdiffstore destset set1 set2

    常用于存储无序的多个元素,比如一条说说、朋友圈赞你的好友,博客文章的分类,联系人分组等。

    要存储多个元素,且这些元素不需要排序。


    sorted set  有序集合

    也叫做zset,元素有序,每个元素都会关联一个分数(整型、浮点型),通过分数的大小来排序。

    元素不能重复,分数可以重复。元素只能是字符串。一个sorted set可以存储2^32-1(42亿+)个元素。

    zadd grade 90 "zhangsan" 98.5 "lisi" #添加|更新一个或多个元素。关联的分数在前,元素在后。分数支持整型、浮点型,负数也可以。如果元素已存在,则更新关联的分数。返回此次操作添加的元素个数

    zrangebyscore grade 90 100 #返回分数在[90,100]上的所有元素
    zrangebyscore grade 90 100 withscores #返回时带上对应的分数

    zscore grade "zhangsan"  #返回该元素关联的分数。比如查询积分。

    zincrby grade 5 "zhangsan" #将指定元素关联的分数+5。比如积分的增减。
    zincrby grade -5 "zhangsan" #负数即减,-5


    zrange grade 0 -1 #返回[0,-1]上的所有元素。
    zrange grade 0 -1 withscores #返回时带上对应的分数
    #zrevrange的用法同上,只不过多了rev,表示按分数降序排列。默认都是按分数升序排列。
    #比如获取排行旁前10的名单



    zrank grade "zhangsan" #返回该元素的位置(下标)。
    #zrevrank用法同上,只不过按分数降序排列
    #比如查询排名





    zcount grade 90 100 #返回分数在[90,100]上的元素个数


    zcard grade #返回元素个数


    zrem grade "zhangsan" "lisi" #删除一个或多个元素

    zremrangebyrank grade 0 2 #删除[0,2]上的所有元素
    zremrangebyscore grade 90 100  #删除分数在[90,100]上的所有元素

     sorted set常用于排行榜,比如阅读排行旁、评论排行榜、推荐排行榜、热搜排行榜、最热视频、最火音乐、热卖商品、人气指数、积分排名等等。

    分数即是衡量指标,上面涉及到下标的操作,默认都是按分数升序排列,可以把前缀z换为zrev,表示按分数降序排列。

    要存储多个元素,且这些元素需要排序。


     说明

    • redis中命令不区分大小写,比如SET、set都是一样的。但是键值对、字段、元素等都要区分大小写。
    • string是基础数据类型,hash、list、set、sorted set都是数据结构
    • hash的字段的值,list、set、sorted set的元素,都只能是字符串,如果要存储其它类型的数据,要加引号作为字符串存储。
  • 相关阅读:
    CSS中的单位简介
    grid-layout
    position
    form
    objects
    个人介绍
    第十二周作业:
    第十一周作业
    第十周web作业
    第九周作业
  • 原文地址:https://www.cnblogs.com/chy18883701161/p/11071609.html
Copyright © 2011-2022 走看看