当前位置: 首页 > news >正文

二级评论列表-Java实现

二级评论列表是很常见的功能,文章记录了新手用Java实现的具体逻辑。

整体实现逻辑是先用2个sql,分别查出两层数据。然后用java在service中实现数据组装,返给前端。这种实现思路好处是SQL简洁,逻辑分明,便于维护。

一:需求场景

一级评论的列表,平铺展示。当涉及多人回复,或者两个人多次对话后, 留言逻辑看着非常混乱。如下图

当改造为二级列表后,数据展示更加直观。如下图, 演示地址:CodingLife 

二、SQL实现

先用2个SQL分别查出两层数据,先查parent_id为空的数据,就是第一层数据。

再用MyBatis的嵌套查询,配置in语句查出所有的二级数据。

    # 一级评论<select id="getuserSideLevel1" resultMap="indexResultMap">select*fromleave_message mlleft join user useron user.id = ml.leave_idwhereparent_id is nullorder bycreate_time desclimit #{start},#{size}</select># 二级评论<select id="getuserSideLevel2" resultMap="indexResultMap">select*fromleave_message mlleft join user useron user.id = ml.leave_idwhereparent_id in<foreach collection="parentIds" item="parentId" open="(" separator="," close=")">#{parentId}</foreach>order bycreate_time asc</select>

三、Java组装

使用Java将两级数据组装在一起,下面为service的具体代码。

        // 先查分页范围内的一级数据List<LeaveMessage> level1List = leaveMessageMapper.getuserSideLevel1(start,size);// 取出一级数据的idList<Integer> parentIdArray = new ArrayList<>();for (int i = 0; i < level1List.size(); i++) {LeaveMessage level1Item = level1List.get(i);Integer id = level1Item.getId(); // 获取 idparentIdArray.add(id);}// 再查以上一级数据的二级数据List<LeaveMessage> level2List = leaveMessageMapper.getuserSideLevel2(parentIdArray);// 组装如上两级数据for (int i = 0; i < level1List.size(); i++) {LeaveMessage level1Item = level1List.get(i);List<LeaveMessage> childList = new ArrayList<>();for (int j = 0; j < level2List.size(); j++) {LeaveMessage child = level2List.get(j);if (level1Item.getId().equals(child.getParentId())) {childList.add(child);}}level1Item.setChild(childList);}return ApiResponse.success(level1List);

四、源码

演示地址为:CodingLife,源码地址为:Git

相关文章:

  • PyTorch深度学习框架60天进阶学习计划 - 第46天:自动化模型设计(二)
  • 实战设计模式之备忘录模式
  • 数量关系 多级数列1
  • ClawCloud的免费空间(github用户登录可以获得$5元/月的免费额度)
  • PostgreSQL 的pgloader 工具介绍
  • Qt C++ 解析和处理 XML 文件示例
  • django基于爬虫的网络新闻分析系统的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
  • 数据驱动未来:大数据在智能网联汽车中的深度应用
  • 2.凸包优化求解
  • 突破速率瓶颈:毫米波技术如何推动 5G 网络迈向极限?
  • 【刷题Day20】TCP和UDP
  • 在STM32的定时器外设中,选择使用哪个外部时钟配置函数
  • 【C++算法】65.栈_删除字符中的所有相邻重复项
  • MOPSO实现无人机多目标路径规划(Matlab完整源码和数据)
  • package.json ^、~、>、>=、* 详解
  • 【java实现+4种变体完整例子】排序算法中【计数排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格
  • 【大模型】 LangChain框架 -LangChain用例
  • [matlab]南海地形眩晕图代码
  • Spring Boot + Caffeine:打造高性能缓存解决方案
  • Elasticsearch:使用 ES|QL 进行搜索和过滤
  • 上海浪琴环球马术冠军赛明日启幕!五一假期在这里感受精彩
  • 4月一二线城市新房价格环比上涨,沪杭涨幅居百城前列
  • 王毅谈金砖国家反恐和网络安全合作
  • 解放日报:“北斗七星”列阵,AI群星闪耀
  • 国务院安委办、应急管理部进一步调度部署“五一”假期安全防范工作
  • 辽宁辽阳火灾3名伤者无生命危险