美文网首页
Redis--数据类型,常用命令和数据结构

Redis--数据类型,常用命令和数据结构

作者: Amy1234567 | 来源:发表于2021-09-03 15:19 被阅读0次

Redis的基本数据类型

1. 字符串--String

String是Redis最基本的类型,可以理解成与Memecached一模一样的类型,一个key对应一个value。String类型是二进制安全的。意味着Redis的string可以包含任何数据。如jpg图片或者序列化的对象。

String类型是Redis最基本的数据类型,一个Redis中的字符串value最多可以是512M.

2. 列表--List

单键多值

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的左边或者右边。它的底层实际是个双向链表,对两端的操作性能很高,通过索引下标的操作中间的节点性能会较差

尚硅谷

Redis数据类型的常用命令

1. String类型常用命令

(1). set  <key><value> 添加键值对

(2). get  <key> 查询对应键值

(3). append <key><value> 将给定的<value> 追加到原值的末尾

(4). strlen <key> 获得值的长度

(5). setnx <key><value> 只有在 key 不存在时    设置key的值

(6). incr <key> 将 key 中储存的数字值增1, 只能对数字值操作,如果为空,新增值为1

(7). decr <key> 将 key 中储存的数字值减1 只能对数字值操作,如果为空,新增值为-1

(8). incrby / decrby  <key> <步长>  将 key 中储存的数字值增减。自定义步长。

(9). mset  <key1><value1><key2><value2> 同时设置一个或多个key-value对 

(10). mget <key1><key2><key3> 同时获取一个或多个value 

(11). msetnx <key1><value1><key2><value2> 同时设置一个或多个key-value 对,当且仅当所有给定key 都不存在。//原子性,有一个失败则都失败

(12). setex  <key><过期时间><value> 设置键值的同时,设置过期时间,单位秒。

(13). getset <key><value> 以新换旧,设置了新值同时获得旧值。

(14). getrange <起始位置><结束位置><value>

    获得值的范围,类似java中的substring,前包,后包

(15). setrange <key><起始位置><value> 

    用覆写<key>所储存的字符串值,从<起始位置>开始(索引从0开始)。

2.  List类型常用命令

(1). lpush/rpush  <key><value1><value2><value3> 从左边/右边插入一个或多个值。

(2). lpop/rpop <key> 从左边/右边吐出一个值。值在键在,值光键亡。

(3). rpoplpush <key1><key2> 从<key1>列表右边吐出一个值,插到<key2>列表左边。

(4). lrange <key><start><stop> 按照索引下标获得元素(从左到右)

    eg. lrange mylist 0 -1   0左边第一个,-1右边第一个,(0-1表示获取所有)

(5). lindex <key><index>按照索引下标获得元素(从左到右)

(6). llen <key>获得列表长度

(7). linsert <key> before <value><newvalue>  在<value>的后面插入<newvalue>插入值

(8). lrem <key><n><value> 从左边删除n个value(从左到右)

(9). lset <key><index><value> 将列表key下标为index的值替换成value

基本数据类型的数据结构

1. String的数据结构为简单动态字符串(Simple Dynamic String,缩写SDS)。是可以修改的字符串,内部结构实现上类似于Java的ArrayList,采用预分配冗余空间的方式来减少内存的频繁分配.

尚硅谷

如图中所示,内部为当前字符串实际分配的空间capacity一般要高于实际字符串长度len。当字符串长度小于1M时,扩容都是加倍现有的空间,如果超过1M,扩容时一次只会多扩1M的空间。需要注意的是字符串最大长度为512M。

2. List的数据结构为快速链表quickList。

首先在列表元素较少的情况下会使用一块连续的内存存储,这个结构是ziplist,也即是压缩列表。它将所有的元素紧挨着一起存储,分配的是一块连续的内存。当数据量比较多的时候才会改成quicklist。

3. Redis的set结构也是一样,它的内部也使用hash结构,所有的value都指向同一个内部值。

4. Hash类型对应的数据结构是两种:ziplist(压缩列表),hashtable(哈希表)。

5. zset底层使用了两个数据结构

(1)hash,hash的作用就是关联元素value和权重score,保障元素value的唯一性,可以通过元素value找到相应的score值。

(2)跳跃表,跳跃表的目的在于给元素value排序,根据score的范围获取元素列表。

应用场景

set: 
(1). 跟踪一下唯一性数据

可以使用Redis Set类型跟踪一些具有唯一性的数据,比如访问某一博客的唯一IP地址信息。这种情况下只需要每次访问时将IP信息存入Redis中,Set数据类型可以自动保持IP信息的唯一性。

(2). 用于维护数据对象之间的关联关系

也可以用Set类型的服务器端聚合计算的方便高效的特性,维护数据对象之间的关联关系,比如购买某一商品的用户ID存入一个Set集合,购买另一个商品的用户存入另一个Set集合,想要获取同时购买两样商品的用户ID。

zset
(1). 游戏的积分排行榜

当玩家的分数增加时,可以用zadd增加玩家的分数,此后通过zrange获取积分等信息。

相关文章

网友评论

      本文标题:Redis--数据类型,常用命令和数据结构

      本文链接:https://www.haomeiwen.com/subject/rwuuiltx.html