之前看了一篇文章,讲redis的应用场景,其中一个应用场景就是实现点赞功能,纸上得来恐觉浅,必须实战一波
功能点设计
比如我喜欢发文章的掘金网站就有点赞的功能,统计文章点赞的总数,用户所有文章的点赞数,因此设计的点赞功能模块具有以下功能点:
某篇文章的点赞数
用户所有文章的点赞数
用户点赞的文章
持久化到MySQL数据库
数据库设计
Redis数据库设计
Redis是K-V数据库,没有统一的数据结构,针对不同的功能点设计了不同的K-V存储结构
用户某篇文章的点赞数
使用HashMap数据结构,HashMap中的key为articleId,value为Set,Set中的值为用户ID,即HashMap>
用户总的点赞数
使用HashMap数据结构,HashMap中的key为userId,value为String记录总的点赞数
用户点赞的文章
使用HashMap数据结构,HashMap中的key为userId,value为Set,Set中的值为文章ID,即HashMap>
MySQL数据库设计
最主要的两张表,article表和user_like_article
article表结构
字段值
字段类型
说明
article_name
varchar
文章名字
content
blob
文章内容
total_like_count
bigint
文章总点赞数
文章总的点赞数需要和Redis中的点赞数进行同步
user_like_article表结构
字段值
字段类型
说明
user_id
bigint
用户ID
article_id
bigint
文章ID
记录用户点赞文章的信息,是一张中间表
说明:表结构设计省略了id、deleted、gmt_creat