zoukankan      html  css  js  c++  java
  • Redis in .NET Core 入门:(4) LIST和SET

    第1篇:https://www.cnblogs.com/cgzl/p/10294175.html

    第2篇 String:https://www.cnblogs.com/cgzl/p/10297565.html

    第3篇 Hash:https://www.cnblogs.com/cgzl/p/10301916.html

    本文介绍Redis的List和SET,可能比较无聊,大多内容来自文档。

    List

    Redis的List是通过Linked List(链表)来实现的String集合,所以插入数据的速度很快。

    但是缺点就是在数据量比较大的时候,访问某个数据的时间可能会很长,但针对这种情况,可以使用Sorted Set,这个一会再说。

    下面看命令

    LPUSH,RPUSH,LRANGE

    LPUSH会向List的左侧(头部)添加一个新的元素,而RPUSH会把新的元素添加到List的右侧(尾部)。

    LRANGE命令可以按索引区间显示List的一部分,它的个试试LRANGE List-Key start end。如果想显示整个list的话,这两个索引就可以是0和-1,其中-1就表示最后一个元素。

    LPUSH和RPUSH,可以一次添加多个元素:

    LPOP,RPOP

    POP动作有两个效果:一个是获取到元素,另一个是把元素从list中删除。

    LPOP就是从左边(头部)POP,RPOP就是从右边(尾部)POP。

    而如果list里面已经没有元素了,这时执行pop就会返回null:

    LTRIM

    LTRIM命令可以对list进行剪切,其格式为LTRIM list-key start end,返回的就是剪切的部分:

    BRPOP,BLPOP

    BRPOPBLPOP这两个命令与RPOP和LPOP类似,但是当list里没有元素的时候,它们可以几秒钟,如果这期间有新的元素添加到了list里,那么就会停止等待返回该元素,否则就会一直等到设定的时间结束,然后返回null:

    例子里面的5 就是等待5秒。

    而如果这个参数改为0,那就是永远等待:

    而当一旦有新的元素加入的时候,该命令就会立即返回元素:

    此外您还应该研究一下RPOPLPUSHBRPOPLPUSH这两个命令。

    自动创建和移除Key

    通过Redis的命令我们可以发现,

    当我们为集合添加元素的时候,如果集合的key不存在,那么Redis会为我们创建一个空的集合,然后再执行插入操作:

    但要注意的是,不可以为不同类型且key已经存在的集合添加新的数据:

    而从集合删除数据的时候,如果集合是空的,那么集合的Key就会自动销毁(Stream类型除外):

    而针对只读命令(例如LLEN,返回list的长度)也具有同样的效果:

    .NET Core 操练LIST

    LPUSH,RPUSH,LRANGE

    结果:

    LPOP,RPOP

    结果:

    LTRIM

    结果:

    BRPOP,BLPOP

    这个说来话长,暂不演示。

    SET

    Redis的SET是无序的String集合,它里面的元素是不会重复的。

    SADD

    SADD命令会添加新元素到SET:

    可以看到一次性可以添加一个或多个元素。

    SMEMBERS

    SMEMBERS可以获取set里所有的元素:

    但是每次调用得到结果的顺序是无法保证的。

    SISMEMBER

    SISMEMBER可以判断某个元素是否在set里:

    返回1表示true,0表示false。

    SINTER

    SINTER可以查看多个set之间的交集:

    SPOP

    SPOP可以随机从set中移除一个或多个元素并返回:

    SUNIONSTORE

    把多个set合并到一个set里可以使用SUNIONSTORE,格式是sunionstore 目标set set1 set2 ...:

    如果只有一个set需要合并的话,那么就相当于是复制:

    SCARD

    SCARD可以获取set的大小:

    SRANDMEMBER

    SRANDMEMBER可以随机获取set里面的元素,但是不会移除它们:

    .NET Core 操练SET

    SADD,SMEMBNERS

    结果:

    SISMEMBER

    结果:

     

    SINTER

    结果:

    SPOP

    结果:

    SUNIONSTORE

    结果:

    SCARD

    结果:

    SRANDMEMBER

    结果:

  • 相关阅读:
    在二元树中查找和为某一值的所有路径
    求整数的二进制表示1的个数
    Javascript AJAX 解析XML 兼容FIREFOX/IE
    DOM解析XML笔记
    Linux c 共享内存
    C Socket 发送/接收数据结构
    Linux c 获取系统内存
    7.5备忘
    linux c 唤醒进程 获取子进程结束状态
    7.1-7.2备忘
  • 原文地址:https://www.cnblogs.com/cgzl/p/10309415.html
Copyright © 2011-2022 走看看