zoukankan      html  css  js  c++  java
  • 【Redis】03 Redis 数据类型、相关补充、常用命令

    redis的数据类型

    1,概述

    使用Redis进行应用设计和开发的一个核心概念是数据类型。

    与关系数据库不同,在Redis中不存在需要我们担心的表,

    在使用Redis进行应用设计和开发时,我们首先应该考虑的是Redis原生支持的哪种数据类型阳适合我们的应该场景,

    此外,我们无法像在关系数据库中那样,使用sql来操作Redis中的数据,

    相反,我们需要直接使用API发送数据反对应的命令,来操作想要操作的数据

    2,字符串类型

    字符串类型是编程语言和应用程序中最常见和最有用的数据类型,也是Redis的基本数据类型之一,

    事实上,Redis中所有键都必须是字符串。

    3,list数据类型

    列表是应用我只是应该程序开发中非常有用的数据类型之一,列表能存在一组对象,

    因此它也可以被用于栈或者队列,

    在Redis中,与键相关的联的值可以是字符串组成的列表,Redis中的列表更像是数据结构中的双向链表。 

    4,hash数据类型

    哈希表示字段和值之间的映射关系,与JAVA中的Map类似,

    Redis数据集本身就可以看做一个哈希,其中字符串类型的键关联到如字符串和列表之类的数据对象,

    而Redis的数据对象也可以再次使用哈希,其字段和值必须 是字符串。

    5,set数据类型

    集合类型是由唯一,无序对象组成的集合(collection).它经常用于测试某个成员是集合中,

    重复项删除和集合运算(求并,交,差集),

    Redis的值对象可以是字符串集合。 

    6,zset(sortset)数据类型

    有序集合是一个类似于set但是更复杂的数据类型,

    单词sorted意为着这种集合中的每个元素都有一个可用于排序的权重,

    并且我们可以按顺序从集合中得到元素在某些需要一个保持数据有序的场景中,使用这种原生的序的特性是很方便的。

    相关知识串讲

    1,单进程单线程

    采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络IO的时间消耗) 

    why?

    多线程处理可能涉及到锁 

    多线程处理会涉及到线程切换而消耗CPU

    单进程不存在线程安全问题

    缺点:

    无法发挥多核CPU性能,不过可以通过在单机开多个Redis实例来完善

    2,默认16个兄弟一起站台

    默认16个数据库,类似数组下表从零开始,初始默认使用零号库

    3,切换数据库命令

    select命令切换数据库

    4,常用基本命令

    dbsize查看当前数据库的key的数量

    flushdb:清空当前库

    Flushall;通杀全部库

    5,其它说明

    统一密码管理,16个库都是同样密码,要么都OK要么一个也连接不上

    Redis索引都是从零开始

    相关命令详解

    官网命令列表:

    http://www.redis.net.cn/order/

    官方文档:

    http://redisdoc.com/

    常用命令:

    keys * 
    获取所有的key
    
    select 0 
    选择第一个库
    
    move myString 1 
    将当前的数据库key移动到某个数据库,目标库有,则不能移动
    
    flushdb 
    清除指定库
    
    randomkey  
    从当前数据库中随机返回
    
    type key 类型
    
    del key1 
    删除key
    
    exists key 
    判断是否存在key
    
    expire key 10 
    10过期
    
    pexpire key 
    1000毫秒
    
    persist key 
    删除过期时间
    
    ttl key 
    查看还有多少秒过期,-1表示永不过期,-2表示已过期

    string类型相关命令

        set name cxx
    
        get name
    
        getrange name 0 -1 字符串分段   0 -1是全部   0 -2  ==n-1
    
        getset name new_cxx 设置值,返回旧值
    
        mset key1 key2 批量设置
    
        mget key1 key2 批量获取
    
        setnx key value 不存在就插入(not exists)
    
        setrange key index value 从index开始替换value
    
        incr age 递增
    
        incrby age 10 递增
    
        decr age 递减
    
        decrby age 10 递减
    
        incrbyfloat 增减浮点数
    
        append 追加
    
        strlen 长度
    
        object encoding key  
        得到key 的类型  

       string里面有三种编码
    int 用于能够副作用64位有符号整数表示的字符串 embstr 用于长度小于或等于44字节 Redis3.x中是39字节,这种类型的编码在内存使用时性能更好 raw 用于长度大于44字节的

    list

      lpush mylist a b c 左插入
    
        rpush mylist x y z 右插入
    
        lrange mylist 0 -1 取出数据集合  0 -1是取出所有   0   1取第第一个和第二个
    
        lpop mylist 弹出集合最后一个元素  弹出之后就没有了哦
    
        rpop mylist 弹出第一个元素  弹出之后就没有了哦
    
        llen mylist 长度  
    
        lrem mylist count value 删除
    
            |-COUNT 的值可以是以下几种:
    
                |--count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。
    
                |--count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。
    
                |--count = 0 : 移除表中所有与 VALUE 相等的值。
    
        lindex mylist 2 指定索引的值
    
        lset mylist 2 n 索引设值
    
        ltrim mylist 0 4   
    
                |--对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
    
                    下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。
    
                    你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
    
        linsert mylist before a 插入
    
        linsert mylist after a 插入
    
                |--命令用于在列表的元素前或者后插入元素。 当指定元素不存在于列表中时,不执行任何操作。
    
                    当列表不存在时,被视为空列表,不执行任何操作。 如果 key 不是列表类型,返回一个错误。
    
        rpoplpush list list2 转移列表的数据
    
                |--命令用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。

    Hash

        hset myhash name cxx
    
             |--命令用于为哈希表中的字段赋值 。
    
                |--如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。
    
                |--如果字段已经存在于哈希表中,旧值将被覆盖。
    
        hget myhash name
    
        hmset myhash name cxx age 25 note "i am notes"
    
        hmget myhash name age note   
    
        hgetall myhash 获取所有的
    
        hexists myhash name 是否存在
    
        hsetnx myhash score 100 设置不存在的  如果存在,不做处理
    
        hincrby myhash id 1 递增
    
        hdel myhash name 删除
    
        hkeys myhash 只取key
    
        hvals myhash 只取value
    
        hlen myhash 长度

    Set

        sadd myset redis 
    
        smembers myset 数据集合
    
        srem myset set1 删除
    
        sismember myset set1 判断元素是否在集合中
    
        scard key_name 个数
    
        sdiff | sinter | sunion 操作:集合间运算:差集 | 交集 | 并集
    
        srandmember 随机获取集合中的元素
    
        spop 从集合中弹出一个元素

    Zset

        zadd zset 1 one
    
        zadd zset 2 two
    
        zadd zset 3 three
    
        zincrby zset 1 one 增长分数
    
        zscore zset two 获取分数
    
        zrange zset 0 -1 withscores 范围值
    
        zrangebyscore zset 10 25 withscores 指定范围的值
    
        zrangebyscore zset 10 25 withscores limit 1 2 分页
    
        Zrevrangebyscore zset 10 25 withscores 指定范围的值
    
        zcard zset 元素数量
    
        Zcount zset 获得指定分数范围内的元素个数
    
        Zrem zset one two 删除一个或多个元素
    
        Zremrangebyrank zset 0 1 按照排名范围删除元素
    
        Zremrangebyscore zset 0 1 按照分数范围删除元素
    
        Zrank zset 0 -1 分数最小的元素排名为0
    
        Zrevrank zset 0 -1 分数最大的元素排名为0
    
        Zinterstore
    
        zunionstore rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 weights 1 1 1 1 1 1 1
  • 相关阅读:
    【转载】#349
    【转载】#346
    【转载】#344
    【转载】#336
    【转载】#335
    【转载】#330
    【转载】#324
    win2008远程桌面卡顿和上传慢的解决方法
    sql2005导出数据字典
    第03组 Alpha冲刺 (6/6)
  • 原文地址:https://www.cnblogs.com/mindzone/p/13452073.html
Copyright © 2011-2022 走看看