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获取积分等信息。
网友评论