1.认识Redis

​ Redis是一种键值型的NoSql数据库,数据是以key,value对的形式存储,value可以是字符串,数值,或者json….

​ 安装好Redis后目录下有三个主要文件:

  • redis-cli: 是redis提供的命令行客户端
  • redis-server: 是redis的服务端启动脚本
  • redis-sentinel:是redis的烧饼启动脚本

​ 直接运行redis-server既可以开启服务端

​ 服务端运行的端口是6379,在config文件中可以设置ip地址,端口,密码等

1.1redis常见命令

​ redis有五种基本类型:String,Hash,List,Set,SortedSet

​ 三种特殊类型:GEO,BitMap,HyperLog

通用命令

  • keys: 查看符合模板的所有key
  • del: 删除一个指定的key
  • exists: 判断key是否存在
  • expire: 给一个key设置有效期,有效期到期时该key会被自动删除
  • ttl: 查看一个key的剩余有效期

1.2 String类型

​ String类型,也就是字符串类型,value是字符串,字符串又分三类:

  • string: 普通字符串
  • int: 整数类型,可以自增自减
  • float:浮点类型,可以自增自减

​ 不管哪一类,底层都是字节数组形式存储,只不过编码方式不同,最大空间不能超过512m

​ 存储时将对象序列化为JSON字符串,修改时不方便

常见命令

  • set: 添加或者修改已经存在的一个string类型的键值对
  • get:根据key获取string类型的value
  • mset: 批量添加多个String类型的vaue
  • mget: 根据多个key获取多个string类型的value
  • incr: 让一个key的整型vaule自增1
  • incrby:自增指定步长 如 incrby num 2 让num自增2
  • incrbyfloat : 浮点型自增指定步长
  • setnx :添加一个String类型的键值对,前提是这个key不存在,否则不执行
  • SETEX:添加一个String类型的键值对,并且指定有效期

Redis的key允许有多个单词形成层级结构,多个单词之间用’:’隔开,格式如下:

项目名:业务名:类型:id

可以通过这个结构实现table的概念

1.3 hash类型

​ 又称散列,value是一个无序字典,类似于Java中的HashMap结构,它可以将对象中的每个字段独立存储,可以针对单个字段做crud

常用命令

  • HSET key field value:添加或者修改hash类型key的field的值
  • HGET key field:获取一个hash类型key的field的值
  • HMSET:批量添加多个hash类型key的field的值
  • HMGET:批量获取多个hash类型key的field的值
  • HGETALL:获取一个hash类型的key中的所有的field和value
  • HKEYS:获取一个hash类型的key中的所有的field
  • HINCRBY:让一个hash类型key的字段值自增并指定步长
  • HSETNX:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行

1.4 list类型

​ 可以看作成一个双向链表结构,可以正向反向索引,特征:

  • 有序
  • 可重复
  • 插入删除快
  • 查询速度一般

常用来存储有序数据,如朋友圈点赞列表,评论列表等

常用命令

  • LPUSH key element … :向列表左侧插入一个或多个元素
  • LPOP key:移除并返回列表左侧的第一个元素,没有则返回nil
  • RPUSH key element … :向列表右侧插入一个或多个元素
  • RPOP key:移除并返回列表右侧的第一个元素
  • LRANGE key star end:返回一段角标范围内的所有元素
  • BLPOP和BRPOP:与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil

1.5 set类型

​ Redis的Set结构与java中的HashSet类似,可以看作一个value为Null的HashMap,它也是一个hash表,特征:

  • 无序
  • 元素不可重复
  • 查找快
  • 支持交集,并集,差集

常见命令

  • SADD key member … :向set中添加一个或多个元素
  • SREM key member … : 移除set中的指定元素
  • SCARD key: 返回set中元素的个数
  • SISMEMBER key member:判断一个元素是否存在于set中
  • SMEMBERS:获取set中的所有元素
  • SINTER key1 key2 … :求key1与key2的交集
  • SDIFF key1 key2 :求key1与key2的差集

1.6 SortedSet类型

​ 可排序的Set集合,与java中的TreeSet有些类似,有一个score属性,可以基于score属性对元素排序,底层的实现是基于一个跳表(Skip List)加hash表。特征:

  • 可排序
  • 元素不重复
  • 查询速度快

经常用来实现排行榜

常用命令

  • ZADD key score member:添加一个或多个元素到sorted set ,如果已经存在则更新其score值
  • ZREM key member:删除sorted set中的一个指定元素
  • ZSCORE key member : 获取sorted set中的指定元素的score值
  • ZRANK key member:获取sorted set 中的指定元素的排名
  • ZCARD key:获取sorted set中的元素个数
  • ZCOUNT key min max:统计score值在给定范围内的所有元素的个数
  • ZINCRBY key increment member:让sorted set中的指定元素自增,步长为指定的increment值
  • ZRANGE key min max:按照score排序后,获取指定排名范围内的元素
  • ZRANGEBYSCORE key min max:按照score排序后,获取指定score范围内的元素
  • ZDIFF、ZINTER、ZUNION:求差集、交集、并集

所有排名默认升序,如果降序则在命令的Z后面加上REV

2.与关系型数据库的区别

  • 不存在关联关系,数据间的联系靠的是代码中的业务逻辑
  • 查询方式多种多样,传统数据库会基于Sql语句查询
  • 事务上不满足ACID(原子性,一致性,隔离性,持久性)原则,而是满足BASE理论
  • 传统存在磁盘,它存在内存,读写速度更快