zoukankan      html  css  js  c++  java
  • Redis数据类型(上)

    数据类型

    1.string(字符串)
    2.hash(哈希,类似java里的Map)
    3.list(列表)
    4.set(集合)
    5.zset(sorted set:有序集合)

    6.基数

    String(字符串)
    string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
    string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
    string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M
    Hash(哈希)
    Redis hash 是一个键值对集合。
    Redis hash是一个string类型的fieldvalue的映射表,hash特别适合用于存储对象。
    类似Java里面的Map<String,Object>
    List(列表)
    Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)
    它的底层实际是个链表
    Set(集合)
    Redis的Set是string类型的无序集合。它是通过HashTable实现实现的
    zset(sorted set:有序集合)
    Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
    不同的是每个元素都会关联一个double类型的分数
    redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。

    命令地址:http://redisdoc.com/

    Redis 键(key)

    1. keys *
    2. exists key的名字,判断某个key是否存在
    3. move key db   --->当前库就没有了,被移除了
    4. expire key 秒钟:为给定的key设置过期时间
    5. ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期,即已被删除
    6. type key 查看你的key是什么类型

    String类型:
    字符串是Redis的最基本额数据结构,以一个键和一个值存储在Redis内部
    类似java的Map结构,通过键去找值

     

    基本命令:

    支持简单运算的命令:

     下面是代码的测试流程:

     

    getrange/setrange
    getrange:获取指定区间范围内的值,类似between......and的关系从零到负一表示全部,默认从0开始
                    0 -1:代表全部
    setrange设置指定区间范围内的值,格式是setrange key值 具体值
                即修改原来字符串额值从某个位置开始 

     

     setex(set with expire)键秒值/setnx(set if not exist)
    setex:设置带过期时间的key,动态设置。
                setex 键 秒值 真实值
    setnx:只有在 key 不存在时设置 key 的值。

     

     mset/mget/msetnx
    mset:同时设置一个或多个 key-value 对。
    mget:获取所有(一个或多个)给定 key 的值。
    msetnx:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在
                否则不生效

    链表List
    链表结构是 Redis 中一个常用的结构,它可以存储多个字符串,而且它是有序的
    Redis 链表是双向的,

     

    使用链表结构就意味着读性能的丧失
    链表只能从 个方向中去遍历所要节点
    优势:在于插入和删除的便利
    链表的数据节点是分配在不同的内存域的,并不连续

     

    由此可见,链表结构的使用是需要注意场景的,对于那些经常需要对数据进行插入和
    删除的列表数据使用它是十分方便的,因为它可以在不移动其他节点的情况下完成插入和
    删除。而对于需要经常查找的,使用它性能并不佳,它只能从左到右或者从右到左的查找
    和比对。

     

     lpush/rpush/lrange
    lpush: 从链表的左边插入
    rpush: 从链表的右边插入
    lrange :查看链表的节点值
                  lrange  list  start    end          end=-1代表全部

     

     lpop/rpop
    lpop:删除左边的第一个节点,并且将其返回
    rpop:删除右边第一个节点,并且将其返回

     

     lindex,按照索引下标获得元素(从上到下)
    lindex:  lindex key index,索引从零开始
    通过索引获取列表中的元素 

     

     llen
    求链表的长度,返回长度

     

     lrem key 删N个value
     * 从left往right删除2个值等于v1的元素,返回的值为实际删除的数量
     *  LREM list3 0 值,表示删除全部给定的值。零个就是全部值
        lrem list 个数  节点值

    ltrim key 开始index 结束index,截取指定范围的值后再赋值给key
    ltrim:截取指定索引区间的元素,格式是ltrim list的key 起始索引 结束索引
           【start end】 开区间    会把截取的内容保存在原来的list中,默认截取位置从0 开始

     rpoplpush 源列表 目的列表
    移除列表的最后一个元素,并将该元素添加到另一个列表并返回
    移除源列表的最后一个元素并且将其左插到目的列表中

     

     lset key index value
    给index出的索引修改值

     

    linsert key  before/after 值1 值2
    在值1 前面/后面  插入值2

     

    它是一个字符串链表,left、right都可以插入添加;
    如果键不存在,创建新的链表;
    如果键已存在,新增内容;
    如果值全移除,对应的键也就消失了。
    链表的操作无论是头和尾效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。
     
    链表的命令都是进程不安全的,
    Red is 提供了链表的阻塞命令,它 在运行的时候 会给链表加锁,以保
    证操作链表的命令安全性,
  • 相关阅读:
    内置函数02
    生成器
    OpenJudge 2979 陪审团的人选 / Poj 1015 Jury Compromise
    OpenJudge/Poj 1936 All in All
    模板:各类型的最大数和最小数表示
    OpenJudge/Poj 1661 帮助 Jimmy
    OpenJudge/Poj 1915 Knight Moves
    OpenJudge 2757 最长上升子序列 / Poj 2533 Longest Ordered Subsequence
    OpenJudge/Poj 1163 The Triangle
    OpenJudge/Poj 1844 Sum
  • 原文地址:https://www.cnblogs.com/Mrchengs/p/10047880.html
Copyright © 2011-2022 走看看