一、String数据类型
String是 redis 最基本的类型,最大能存储 512MB 的数据,String类型是二进制安全的,即可以存储任何数据、比如数字、图片、序列化对象等
1、append
#Redis的append命令是往一个key追加value。如果没有key,则创建一个并且设置value
格式:APPEND key value
2、set
#获取数据
格式:SET key value #若值为字符串则需要加单引号或双引号
3、srelen
#获取值的字符长度
4、incr、decr、incrby、decrby
#这些仅适用于值为整数时
incr #该key的值增加1
decr #该key的值减少1
incrby #增加指定的整数
decrby #减少指定的整数
5、getset
#获取计数器原有值的同时,并将其设置为新值,这两个操作原子性同时完成
格式:GETSET key value
6、setex与ttl
setex #设置指定key的存活时间
格式:SETEX key seconds value
#key的生命周期
格式:TTL key
7、setnx
#创建指定键,若该键存在则执行,若不存在则不执行
格式:SETNX key value
8、mset、mget、msttnx
mset #批量创建键值并设值
mget #批量获取键值
msetnx #批量设置键值,若存在的键则不执行
二、List数据类型
#列表的元素类型为string,按照插入顺序排序,在列表的头部或尾部添加元素
1、lpush、lpushx、lrange
lpush
#\该命令会创建该键及与其关联的List,之后在将参数中的values从左到右依次插入到表头
lpushx
#该命令仅当key存在时,将value值插入表头
lrange
#返回列表中指定区间内的元素,0表示第一个元素,1表示第二个元素
2、lpop、llen
lpop #移除并返回第一个元素
llen #查看列表中元素的个数
3、lrem、lset、lindex、ltrim
LREM key count value #从头到尾,删除count(数值)的value值
LSET key index value #将索引值设为新的值
LINDEX key index #获取索引值为index的值
LTRIM key start stop #保留start到stop的值
4、linsert
LINSERT key BEFORE|AFTER pivot value
#在键值中某一个元素前|后插入一个新元素
5、rpush、rpushx
rpush #将值从左到右插入
rpushx #将值从左到右插入,键值以存在则执行,不存在则不执行
6、rpop、rpoplpush
rpop #移除最后一个元素并显示
rpoplpush #将键值1的最后一个值移到键值2 的第一个值
三、Hash数据类型
hash用于存储对象。可以采用这样的命名方式:对象类别和ID构成键名,使用字段表示对象的属性,而字段值则存储属性值
如果Hash中包含很少的字段,那么该类型的数据也将仅占用很少的磁盘空间。每一个Hash可以存储4294967295个键值对
1、hset、hget、hdel、hexists、hlen、hesetnx
HSET key field value #给xxx键值设置xxx字段输入xxx值
HGET key field #获取键值的xxx字段的值
HDEL key field #删除xxx键值的xxx字段的值,成功则返回1
HEXISTS key field #判断xxx键值的xxx字段是否存在,成功则返回1
HLEN key #查看xxx键值的字段数量
HSETNX key field value #给xxx键值新增xxx字段及内容,是否执行基于此字段是否存在,不管键是否存在,返回1表示执行成功
2、hincrby
HINCRBY key field increment #给xxx键xxx字段追加x值
3、hmset、hmget、hgetall、hkeys、hvals
HMSET key field value #批量为xxx键创建字段和输入值
HMGET key field #批量查看字段内容
HGETALL key #列出xxx键的所有字段以及对应的值
HKEYS key #列出所有字段名
HVALS key #列出所有字段的值
四、set数据类型(无序集合)
无序集合,元素类型为String类型,元素具有唯一性,不允许存在重复的成员。多个集合类型之间可以进行并集、交集和差集运算
应用范围
第一种范围:可以使用Redis的Set数据类型跟踪一些唯一性数据,比如访问某一博客的唯一IP地址信息。对于此场景,我们仅需在每次访问该博客时将访问者的IP存入Redis中,Set数据类型会自动保证IP地址的唯一性
第二种范围:充分利用Set类型的服务端聚合操作方便、高效的特性,可以用于维护数据对象之间的关联关系。比如所有购买某一电子设备的客户ID被存储在一个指定的Set中,而购买另外一种电子产品的客户ID被存储在另外一个Set中,如果此时我们想获取有哪些客户同时购买了这两种商品时,Set的intersections命令就可以充分发挥它的方便和效率的优势了
1、sadd、smembers、scard、sismember
SADD key member #将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。假如集合 key 不存在,则创建一个只包含添加的元素作成员的集合
SMEMBERS key #通过smembers命令查看插入的结果,输出的顺序与插入顺序无关
SCARD key #查看键值中元素的数量
SISMEMBER key member #查看键值中某一元素是否存在,返回0表示不存在,1表示存在
2、spop、srem、srandmember、smove
SPOP key [count] #随机的移除并返回键中的某一成员
SREM key member #从键值中移除一个或多个成员,并返回移除成员个数
SRANDMEMBER key [count] #随机返回键值中的某一成员
SMOVE source destination member #将键值1的值移到键值2的值
五、Sorted Set数据类型(zset、有序集合)
有序集合,元素类型为Sting,元素具有唯一性,不能重复
每个元素都会关联一个double类型的分数score(表示权重),可以通过权重的大小排序,元素的score可以相同
应用范围:
可以用于一个大型在线游戏的积分排行榜。每当玩家的分数发生变化时,可以执行ZADD命令更新玩家的分数,此后再通过ZRANGE命令获取积分TOP10的用户信息。当然我们也可以利用ZRANK命令通过username来获取玩家的排行信息。最后我们将组合使用ZRANGE和ZRANK命令快速的获取和某个玩家积分相近的其他用户的信息
Sorted-Set类型还可用于构建索引数据
1、zadd、zcard、zcount、zrem、zincrby、zscore、zrank
ZADD key [NX|XX] [CH] [INCR] score member #将一个或多个成员元素及其分数值加入到有序集当中
ZCARD key #获取键值中值得数量
ZCOUNT key min max #分数满足表达式大于小于值得成员数量
ZREM key member #删除成员XXX,XXX返回实际删除成员的数量
ZINCRBY key increment member #成员xxx不存在时,zincrby命令将添加该成员并假设其初始分数为0
ZSCORE key member #获取某成员的分数
ZRANk key member #指出对面索引数
2、zrangebyscore、zremrangebyrank、zremrrangebyscore
zrangebyscore #获取分数满足表达式x <= score <= x的成员
zremrangebyrank #删除位置索引满足表达式x <= rank <= x的成员
zremrrangebyscore #删除分数满足表达式x <= score <= x的成员,并返回实际删除的数量
3、zrevrange、zrevrangebyscore、zrevrank
ZREVRANGE key start stop #以位置索引从高到低的方式获取并返回此区间内的成员
ZREVRANGEBYSCORE key max min #获取分数满足表达式x >= score >= x 的成员,并以从高到底的顺序输出
ZREVRANk key member #获取成员索引