redis数据类型及常用命令
一.redis数据类型
Redis的五大数据类型
1.string(字符串)
String(字符串)
string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M
2.hash(哈希,类似java里的Map)
Hash(哈希)
Redis hash 是一个键值对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
类似Java里面的Map<String,Object>
3.list(列表)
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
它的底层实际是个链表
4.set(集合)
Set(集合)
Redis的Set是string类型的无序集合。它是通过HashTable实现实现的,
5.zset(sorted set:有序集合)
zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。
redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。(比如游戏中划分名称,杀了60个怪的一个名称,70个怪的一个名称,80的一个名称,90的一个名称,100的一个名称,那玩家可能就会被分成不同的区间从而达到分组的效果)
二.基本命令操作
keys
1.keys
2. exists key的名字,判断某个key是否存在
3. move key db --->当前库就没有了,被移除了
4. expire key 秒钟:为给定的key设置过期时间
5. ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期
6. type key 查看你的key是什么类型
字符串(string)
应用场景
常规自动计数,微博粉丝,订阅数,点赞数等
特点:单值单value
1. set/get/del/append/strlen
2.Incr/decr/incrby/decrby,一定要是数字才能进行加减
redis字符串的这一功能也凸显了redis字符串的应用场景:常规自动计数,微博粉丝,订阅数,点赞数等等,并且redis提供的这个简单的命令即可完成数的自动增减以及幅度
3. getrange/setrange
getrange:获取指定区间范围内的值,类似between......and的关系
从零到负一表示全部
setrange设置指定区间范围内的值,格式是setrange key值 具体值
4. setex(set with expire)键秒值/setnx(set if not exist)
setex:设置带过期时间的key,动态设置。
setex 键 秒值 真实值
setnx:只有在 key 不存在时设置 key 的值。
5. mset/mget/msetnx
mset:同时设置一个或多个 key-value 对。
mget:获取所有(一个或多个)给定 key 的值。
msetnx:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。
6. getset(先get再set)
getset:将给定 key 的值设为 value ,并返回 key 的旧值(old value)。
简单一句话,先get然后立即set
列表(List)
应用场景
消息队列,比如微信朋友圈展示,是按时间远近来逐条展示的,微博亦是如此
特点:单值多value
1. lpush/rpush/lrange
2. lpop/rpop
3. lindex,按照索引下标获得元素(从上到下)
通过索引获取列表中的元素 lindex key index
4. llen
5. lrem key 删N个value
* 从left往right删除2个值等于v1的元素,返回的值为实际删除的数量
* LREM list3 0 值,表示删除全部给定的值。零个就是全部值
6. ltrim key 开始index 结束index,截取指定范围的值后再赋值给key
ltrim:截取指定索引区间的元素,格式是ltrim list的key 起始索引 结束索引
7. rpoplpush 源列表 目的列表
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
8. lset key index value
9. linsert key before/after 值1 值2
列表性能总结:
它是一个字符串链表,left、right都可以插入添加;
如果键不存在,创建新的链表;
如果键已存在,新增内容;
如果值全移除,对应的键也就消失了。
链表的操作无论是头和尾效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。
集合(set)
应用场景
例如qq,微博应用中,会将一个每个用户所有的关注人放入一个集合,将每个用户所有的粉丝存在另一个集合,那么我们就可以对集合类型的数据结构做交叉并集的操作,从而得到类似于共同关注,共同喜好,二度好友等功能
特点:单值多value
1. sadd/smembers/sismember
2. scard,获取集合里面的元素个数
获取集合里面的元素个数
3. srem key value 删除集合中元素
4. srandmember key 某个整数(随机出几个数)
* 从set集合里面随机取出2个
* 如果超过最大数量就全部取出,
* 如果写的值是负数,比如-3 ,表示需要取出3个,但是可能会有重复值。
5. spop key 随机出栈
6. smove key1 key2 在key1里某个值
作用是将key1里的某个值赋给key2
7. 数学集合类
1.差集:sdiff, 交集:sinter, 并集:sunion
哈希(Hash)
应用场景
非常适合存储值对象的信息,如一个用户对于的用户名,年龄,性别,等一系列信息
特点:KV模式不变,但V是一个键值对
1. hset/hget/hmset/hmget/hgetall/hdel
2.hlen, hexists key 在key里面的某个值的key
3. hkeys/hvals
4. hincrby/hincrbyfloat
5. hsetnx
不存在赋值,存在了无效。
有序集合(Zset)
应用场景
排行榜,积分榜,各种对比排行数据的应用场景
在set基础上,加一个score值。
之前set是k1 v1 v2 v3,
现在zset是k1 score1 v1 score2 v2
1. zadd/zrange
无序集合可以用在游戏中的给玩家分段的操作中,下面设置的数值60,70,80为分段标准,对应的v1,v2,v3就是一系列的元素value
2. zrem key 某score下对应的value值,作用是删除元素
删除元素,格式是zrem zset的key 项的值,项的值可以是多个
zrem key score某个对应值,可以是多个值
3. zcard/zcount key score区间/zrank key values值,作用是获得下标值/zscore key 对应值,获得分数
zcard :获取集合中元素个数
zcount :获取分数区间内元素个数,zcount key 开始分数区间 结束分数区间
zrank: 获取value在zset中的下标位置
zscore:按照值获得对应的分数
4. zrevrank key values值,作用是逆序获得下标值
正序、逆序获得下标索引值
5. zrevrange
6. zrevrangebyscore key 结束score 开始score
zrevrangebyscore zset1 90 60 withscores 分数是反着来的