zoukankan      html  css  js  c++  java
  • redis学习笔记(1)

    最近在学习redis,做了比较详细的学习笔记,分享给大家,欢迎一起讨论和学习

    第一部分,简单介绍redis 和 redis的基本操作

    NoSQL的特点 :
    数据库种类繁多,但是一个共同的特点都是去掉关系数据库的关系型特性.
    数据之间无关系,这样就非常容易扩展,也无形之间,在架构的层面上带来了可扩展的能力.
    NoSQL无需事先为要存储的数据建立字段,随时可以存储自定义的数据格式,
    而在关系型数据库里,曾删字段是一件很麻烦的事情,数据量大就容易卡死.

    redis 是什么,能干什么
    redis 是一个基于内存的以key-value存储的并且支持持久化nosql数据库,
    可以用来做缓存,消息队列,等

    一, redis 基本操作命令
    get key --得到key
    set key string --设置key
    keys * --查看所有的key
    EXISTS key --判断这个key是否存在
    move key db --移动key到某个库,当前库就没有了
    expire key --给key设置过期时间,单位秒,过期后key就清除
    ttl key --查看key还有多少秒过期,-1表示永不过期,-2表示已过期,其他的数字是单位秒.
    type key --查看key是什么数据类型.
    DEL key --删除某个key


    redis数据类型
    1,String --单key 单value
    set/get/del/append/strlen
    incr 自加1,
    decr 自减1
    incrby 加上多少
    decrby 减去多少
    --必须是数字才能进行加减

    getrange --获取指定区间内的值,类似于截取字符串,getrange key 0 3;获取key第0到第3个中间的字符串.
    setrange --设置指定区间范围内的值,setrange key 位置 具体值. 原来位置的值将被替换.
    --加入test="abcdef", setrange test 0 xxx,把test从第0位开始,设置成xxx4. 结果是"xxxdef"

    setex(set with expire)键秒值,set k1 10 abc,设置一个键是k1,值是abc, 存活10秒,
    setnx(set if not exist),setnx k1 abc , 如果k1存在,就不会设置.

    mset(more set) --同时设置多个key, mset k1 a k2 b k3 c
    mget --同时get多个key, mget k1 k2 k3
    msetnx --同时设置多个值,只要其中有一个key重复的,就不成功, 所有key不存在的才成功.
    getset(先get再set) --

    2,List --单key多value
    lpush --lpush list0 1 2 3 4 5 6 7,从左边开始依次写入数据,(先进后出)
    rpush --rpush list1 1 2 3 4 5 6 7,从右边开始依次写入数据,(先进先出)
    lrange --lrange list0 0 -1,从左边,依次取出数据.

    lpop --从左边,取出第一个值,清除
    rpop --从右边,取出第一个值,清除

    lindex --根据索引下标获得元素,(从上到下),索引从0开始.
    llen --获取list的长度

    lrem key --删除N个value, lrem list0 2 a, 在list里面删除2个a.
    ltrim key --截取指定范围的值后再复制给key.index开始,index结束

    rpoplpush 源 目标 --rpoplpush list0 list1,list0右边出站一个,从左边追加上list1上;

    lset key index value --给某个下标设置具体的值;
    insert key before 值 after --把befrore 和after 插入到已经存在的值前后.

    List总结:
    它是一个字符串链表,left,right都可以插入添加,
    如果键不存在,创建新的链表; 键存在,新增内容; 如果值全部移除,对应的键也消失;
    链表的操作无论是头和尾效率都高,但对中间元素操作,效率就低;


    3,Set --单key多value
    sadd --添加set元素;sadd set01 1 1 2 2 3 3,重复的会不添加;
    smembers --取出set元素;SMEMBERS set01
    sismember --sismember key 元素,判断是否存在元素

    scard --scard key;获取集合里面的元素的个数.
    srem key value --删除集合中某个元素;srem set01 1

    srandmember key 某个整数(例如:3) --在key里面,随机出3个value;
    spop key --随机出栈,一次出一个;

    smove key1 key2 key1某个值 --把key1里面某个值移到key2,值的迁移;

    数学集合类:
    差集:sdiff key1 key2 --在第一个set里面,不在第二个set里面
    交集:sinter --都在两个set里面
    并集:sunion --在key1,或在key2里面, 有去重功能


    4,Hash --kv模式不变,但v是一个键值对;
    hset --hset user id 11(key 是user,value 是 id:11),
    hget --hget user id:
    hmset --同时设置多个k v,hmset cust id 11 name xiepng sex man
    hmget --同时获取多个key的值, hmget cust id name sex
    hgetall --获取这个key里面的所有的 k v, hgetall cust
    hdel --删除这个key里面的额某个 k v ;

    hlen --计算设个key的长度,里面有几个 k v ;

    hexists key --在key里面是否存在某个值,hexists cust id

    hkeys key --获取这个key下面所有的keys,, hkeys cust;
    hvals key --获取这个key下面所有的values,, hvals cust;

    hincrby --某个指定的key加上某个整数(加小数会报错)
    hincrbyfloat--某个指定的key加上某个小数 (加正数也不会报错)

    hsetnx --如果不存在就set某个可以;重复了不添加(只能加单个key)


    5,ZSet --(有序集合,sorted set)
    在set基础上,加一个score.
    之前set是 k1 v1 k2 v2
    现在是 k1 score v1 k2 score v2

    zadd --zadd zset1 60 v1 70 v2 80 v3 90 v4 100 v5
    zrange --zrange zset1 0 -1
    ZRANGE zset01 0 -1 withscores ,

    zrangebyscore key 开始score 结束score ,withscores(,不包含 limit开始下标,多少个;
    -- ZRANGEBYSCORE zset1 (60 (90 limit 0 1
    返回zset1里面score是60到90之间的(不包含60和90),范围是从第0个开始,截取1个

    zrem key 某个score下对应的value值;作用是删除元素;-- ZREM zset1 v5

    zcard --ZCARD zset1 ;计算这个key里面有多少个 kv对
    zcount key score区间; --ZCOUNT zset1 60 90,计算这个key里面的score在这个范围内的有多少个;
    zrank key values值,作用是获取下标值,这个value是第几个下标;--ZRANK zset1 v4
    zscore key 对应值,获取分数;--ZSCORE zset1 v2

    zrevrank key values值,作用是逆序获得下标值; -- ZREVRANK zset1 v4
    zrevrange 逆转取出指定范围内的值 ; --ZREVRANGE zset1 0 -1
    zrevrangebyscore key score2 score1 ;逆转取出score范围内的值 --ZREVRANGEBYSCORE zset1 90 60

    要删除zset 整个集合, 直接del key 即可;

  • 相关阅读:
    2018百度之星初赛B轮 rect
    八数码问题(九宫格重排) 利用康托展开 判重
    2018百度之星初赛A轮 度度熊拼三角
    2018百度之星初赛A轮 度度熊学队列
    MongoDB(课时22 唯一索引)
    MongoDB(课时21 索引)
    MongoDB(课时20 游标)
    MongoDB(课时19 数据删除)
    MongoDB(课时18 修改器)
    MongoDB(课时17 更新函数)
  • 原文地址:https://www.cnblogs.com/ccxp/p/8679055.html
Copyright © 2011-2022 走看看