Redis-常用命令
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理论
- 传统存在磁盘,它存在内存,读写速度更快

