美文网首页
Redis内容总结

Redis内容总结

作者: 代码potty | 来源:发表于2018-10-15 22:31 被阅读0次

    Redis支持五种的数据类型

    1、String
    2、hash
    3、list
    4、set
    5、sorted set

    String数据类型

    getrange key start end:返回key中字符串值的子字符
    setrange key offset value:用value参数覆写给定Key所存储的字符串值,从offset开始
    strlen:获取字符串长度
    set key value:设置key value
    get key:获取value
    setex key value: 原子方式设置key value
    setbit key offset value:设置字符串offset位上的值,为0或1


    hash数据类型

    hlen :获取长度
    hget key field :获取值
    hset key field value:单个添加
    hmset key field1 value1 field2 value2 ..一起添加
    hexists key field判断键是否存在
    hdel key field删除key中的一个field
    hkeys key 获取所有哈希表中的字段
    hvals key 获取哈希表中所有的值
    hsetnx key field value :当key中field不存在,设置这个字段的值


    list双端链表数据类型

    llen :输出列表长度
    lpush:左输入
    rpush:右输入
    blpop key timeout:移除并获取列表第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。(假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。)

    brpop key timeout:移除并获取列表最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
    lpop:简单移除并获取第一个元素
    rpop:简单移除并获取最后一个元素
    lindex key index:通过索引获取列表中的元素
    lset key index value:通过索引设置列表元素的值
    lrange key start stop:获取列表指定范围内的元素
    ltrim key start stop:对列表进行修剪,只保留区间内的元素
    rpoplpush source targe:将source链表最后一个元素弹出并且插入到targe链表中,最后返回这个元素的值


    Set:String类型的无序集合,且不允许重复元素

    sadd key value:添加元素
    srem key member1 member2:移除集合中一个或多个成员

    scard key :获取集合的成员数
    smembers key :获取集合所有的成员
    sismember key member:获取member是否是key中的

    sdiff key1 key2:获取多个key的差集
    sinter key1 key2:获取多个key的交集
    sunion key1 key2:获取多个key的并集

    smove sourve targe member:将sourve中的member移到targe中
    spop key:移除并且返回集合中一个随机元素
    srandmember key [count]:返回集合中一个或多个随机数


    Sorted Set:有序集合

    //与set类似,不同的是每个元素都会关联一个double类型的分数。
    //redis正是通过分数来为集合中的成员进行从小到大的排序。

    zadd key score1 member [score2 member2]:向有序集合添加一个或多个成员,或者更新已存在成员的分数
    zrem key member [member..]移除有序集合中的一个或多个成员

    /按照正常分数从低到高排序/
    zrange key start stop :返回有序集合指定区间内的成员(默认从低到高排序)(start:0;end:-1代表查询这个Key所有的成员)
    zrangebyscore key min max[withscores]:通过分数返回有序集合指定区间内的成员
    zrank key member:返回该成员的索引

    /rev代表的是reverse(反转)/
    zrevrange key start stop[withscores]:返回有序集合指定区间内的成员,按照分数从高到低排序
    zrevrangebyscore key max min[withscores]:返回有序集合指定分数区间内的成员,分数从高到低排序
    zrevrank key member:返回有序集合中指定成员的排名,有序集合是按分数(从大到小)排序

    zcard key :获取有序集合的成员数
    zcount key min max:计算有序集合指定区间分数的成员数
    zscore key member:返回该成员的分数值

    zremrangebyrank key start stop:移除有序集合中给定排名区间的所有成员
    zremrangebyscore key min max:移除给定分数区间的所有成员

    zinterstore targe numkeys(交集的key个数) key1 key2..:计算给定一个或者多个有序集的交集并将结果存储到targe中
    注意:此时交集结果成员的分数为多个有序集分数的总和
    zunionstore targe numkeys key1 keys2:并集,与交集类似,最后的分数也是多个有序集分数的总和
    注意:有序集合的redis没有提供多个集合差集的方法,这是跟无序集合的区别之一


    redis发布订阅(redis用作消息队列)

    1、subscribe channel[channel..] 订阅一个或者多个频道的信息
    2、publish channel message 将消息发送到指定的频道
    3、unsubscribe channel [channel ..] 退订一个或者多个频道的信息
    4、psubscribe pattern [pattern ...] 订阅一个或者多个符合给定模式的频道
    5、punsubscribe pattern [pattern ..] 退订一个或者多个符合给定模式的频道
    6、pubsub subcommand [argument [argument]] 查看订阅与发布系统状态
    参考链接:https://blog.csdn.net/qq_34212276/article/details/78455004

    redis事务

    redis事务可以一次执行多个命令,并且带有两个重要的保证:
    1、redis使用multi开始一个事务,然后开始写redis命令,最后通过exec命令执行事务
    exec命令执行事务的过程中有任意命令执行失败,其余命令依然被执行,之前执行的命令也不会回滚
    2、事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令序列中

    我们知道单个redis命令的执行是原子性的,但是redis事务不具备原子性机制,可以理解为一个打包批量执行的脚本

    方法:
    1、discard:取消事务,放弃执行事务块内所有命令
    2、exec:执行所有事务块内的命令
    3、multi:标记一个事务块的开始
    4、unwatch:取消watch命令对所有Key的监视
    5、watch key :监视一个或者多个key,如果在事务执行之前这个key被其他命令改动,那么事务将被打断

    相关文章

      网友评论

          本文标题:Redis内容总结

          本文链接:https://www.haomeiwen.com/subject/yzbqzftx.html