1.string类型
1-1 string类型数据的基本操作添加 / 修正数据:set key value
获取数据:get key

删除数据:del key
添加 / 修正多个数据:mset key value key1 value1
获取多个数据:mget key key1
追加信息到原始数据后边(不存在时则添加):append key value
1-2 string类型 增减操作设置数值增加指定例模的值:incr key 默认每次加1 | incrby key value 每次新增value设置数据减少指定例模:decr key | decrby key value 跟新增是一回事
运用处景
掌握数据库表主键id,为数据库表供应主键天生策略,担保数据表主键的同等性。
1-3 string类型 时效操作设置过期韶光:setex key seconds value
运用处景
实现限定韶光投票功能:例如一个微信一个小时可以投一次实现热点信息:例如电商行业热门商品、新闻网站热门新闻
1-4 string类型的运用处景微博大V主页高频的访问,对付粉丝数、关注数、微博数都须要时时更新。这个就属于高频信息了,我们就可以利用redis的string类型来办理
在redis中为大V设定用户信息,以用户主键和属性为键值,以下为实现案例。
在这里须要大略的说一下key的命名规则:以表名+主键+主键值+字段 :字段值。以这样的规则来命名就可以很好的来管理我们的键值。
我们还可以利用其余一种办法来实现,便是键后边直接跟一个构造,例如
以上的俩种办法都是可以实现的,只是第一种可以很方便的对任意一个值进行管理,第二种是改一个都得改一次,看业务场景,定时刷新就行。
2. hash类型2-1 hash类型数据的基本操作添加 / 修正数据:hset key field value
获取数据:hget key field | hgetall key
删除数据:hdel key field field1
添加 / 修正多个数据:hmset key field value field1 value1
获取多个数据:hmget key field field1
获取表中字段数量:hlen key
获取表中是否存在某个字段:hexists key field
2-2 hash类型数据的扩展操作获取hash表中所有的字段值:hkeys key
获取hash表中所有的字段值:hvals key
设置指定字段的数值增加指定例模的值:hincrby key field increment | hincrbyfloat key field increment
2-3 hash业务场景之购物车此图来源于网络非低廉甜头,只是仿照购物车场景
在上图中,我们可以看到购物车里的信息,下来咱们利用redis来对这个购物车的实现。
这里实现了一个添加购物车和获取购物车,keys的命名为 表名+主键+主键值
在上图中,我们会有一个问题便是商品信息存储会大量重复,所有我们也须要将商品单独给一贯hash。如下图,只存储商品id
这里供应了俩种设置办法,一种是设置多个字段,一种是直接存储为json。信息不常常变动的话可以利用json
给大家在供应一个方法hsetnx key field value,如果有则不进行添加,没有则添加。这个功能就利用在不同的用户添加同样的商品时不会实行覆盖和无用操作
3. list类型
数据存储需求:存储多个数据,并对数据进行存储空间的顺序进行区分须要的数据构造:一个存储空间保存多个数据,且通过数据可以表示进入顺序list类型:保存多个数据,底层利用双向链表存储构造实现
3-1 list类型数据的基本操作添加 / 修正数据:lpush key value value1 | rpush key value value1
获取数据:lrange key start end | lindex key index | llen key
删除数据:rpop key | lpop key
3-2 list类型数据的扩展操作
在规定韶光内获取并移除数据:blpop key1 key2 timeout | brpop key1 key2 timeout
这个功能大略的写一个案例,随意马虎理解
左边这个终端指令实行后会等待30秒的韶光返回删除的数据
当右边的添加指令实行后左边会直接返回返回删除的数据
3-3 list业务场景
在上边我们知道了list的根本操作 实行 lpop key 或者 rpop key可以从做或者从右进行删除,但是现在有个场景是朋友圈点赞业务,然后从中间取消数据。案例如下图
我们先往list5里边添加 a b c d然后移除c在查看就剩下a b d了
4. set类型
新的存储需求:存储大量的数据,在查询方便供应更高的效率须要的存储构造:能够保存大量的数据,高效的内部存储机制,便于查询set类型:与hash存储构造完备相同,仅存储键,不存储值(nil),并且值是不许可重复的
4-1 set类型数据的基本操作
添加 / 修正数据:sadd key member member1
获取数据:smembers key
删除数据:srem key member1
获取凑集数据总量:scard key
判断凑集中是否包含指天命据:sismember key member
4-2 set类型数据扩展操作
随机获取凑集中指天命量的数据:srandmember key count
随机获取凑集中某个数据并将改数据集移除凑集:spop key
4-3 set类型业务场景推举信息随机推送热点信息、热点新闻、热卖旅游、运用app推举、关注推举等
由于最近咔咔在写discuz,这个案例就以实现关注推举。
案例一:根据一定的推举机制往set里边存放对应的用户,然后每次进行随机获取2位须要推举的用户
案例二:根据一定的推举机制往set里边存放对应的用户,然后根据日期每天推举的用户都不能重复
4-4 set类型业务场景挖掘用户关系
俩个凑集的交、并、差集
sinter key key1
sunion key key1
sdiff key key1
俩个凑集的交、并、差集并存储到指定凑集中
sinterstore destination key1 key2
sunionstore destination key1 key2
sdiffstore destination key1 key2
案例:我们须要挖掘一个信息的共同好友。例如微信公众年夜众号的共同关注好友数量、QQ添加新好友的推举机制、深度挖掘用户直接的联系
就根据上述案例,我们可以利用差集来实现qq的有可能认识的好友。
4-5 set类型业务场景 实现网站的PV UV IP的记录PV直策应用string类型的incr统计即可
UV和IP都是独立不重复的,利用set来操作。
在上边我们知道set有一个特性便是不能重复,我们就可以根据这一点来轻松实现这个功能。然后利用scard key 来统计数量。
至于UV是独立访客,利用本地的cookie来实现就可以,方法一样把cookie传给redis做记录即可
5. sorted_set类型
在之前的四个类型中都不支持排序的,下来咱们看的sorted_set类型是既支持存储大数据,也支持排序功能
5-1. sorted_set类型基本操作添加数据:zadd key score member
获取数据:zrange key start stop | zrevrange key start stop
删除数据:zrem key member
按条件获取数据:zrangebyscore key min max limit | zrevrangescore key max min
条件删除数据:zremrangebyrank key start stop | zremrangebyscore key min max
获取凑集数据总量:zcard key | zcount key min max
凑集交、并操作:zinterstore destination numkeys key | zunionstore destination numkeys key(这个指令就不做演示了,可以自己查看文档。跟set有点类似,只不过会把所有交集的和给加起来。然后这里边有个numkeys这个参数是一共几个key进行打算 后边的key就须要几个)
获取数据对应的索引:zrank key member | zrevrank key member
socre值获取与修正:zscore key member | zincrby key increment member
总结以上便是redis数据类型的大略先容和详细运用,在后文中会针对详细需求在进行实战。