发表于: 2019-12-19 21:49:02

1 1146


一、今天完成的事

1.复习Redis

1.redis数据类型

Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

2.String

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

3.hash

Redis hash 是一个键值(key=>value)对集合。

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

4.List

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

5.set

Redis 的 Set 是 string 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

6.zset(sorted set:有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

二、遇到的问题

解决了巨他妈烦的需求

点赞收藏要显示,不仅要显示点赞多少,收藏多少,还要显示谁现在收藏了谁,谁点赞了谁

   /**
    * 所有视频列表
    * @param video
    * @return
    */
   @Select("<script>select distinct video.id,video.title, video.grade,video.subject,video.video_image,video.number_of_likes, " +
           "video.number_of_collections,video.classification,video.video_url,video.content,video.introduction,video.update_at," +
           "teacher.teacher_id,teacher.teacher_name,teacher.teacher_image,video_collection.collection_sid,video_like.like_sid from video \n" +
           "left join teacher_video on teacher_video.vid =video.id   \n" +
           "left join teacher on teacher.teacher_id = teacher_video.tid\n" +
           "left join video_collection on video_collection.vid=id\n" +
           "left join video_like on video_collection.vid=id\n" +
           "<where>  1=1 " +
           "<if test= \"grade != null\">and video.grade=#{grade}</if>\n"+
           "<if test= \"subject != null\">and video.subject=#{subject}</if>\n"+
           "<if test= \"classification != null\">and video.classification=#{classification}</if>\n" +
           "</where> order by update_at desc"+
           "</script>\n")
   List<Video> selectVideoList(Video video);

修改表数据

加了一个video_like表

修改完成后实现

如果该用户收藏了返回collection_sid,点赞了返回like_sid


然后出现了重复数据。查询之后出现多条重复数据,我的问题是写了联表查询,多表关联了。

解决方法是在select 后面跟一个distinct关键字,表示唯一,sql语句如上。

三、收获

四、明天的计划

明天继续做缓存



返回列表 返回列表
评论

    分享到