实现课程列表接口

1、带条件查询带分页的课程列表

(1)创建条件查询的vo 在service_edu模块中com/atguigu/eduservice/entity/vo编写CourseQueryVo类。

java 复制代码
@Data
public class CourseQueryVo {

    @ApiModelProperty(value = "课程名称")
    private String title;

    @ApiModelProperty(value = "讲师id")
    private String teacherId;

    @ApiModelProperty(value = "一级类别id")
    private String subjectParentId;

    @ApiModelProperty(value = "二级类别id")
    private String subjectId;

    @ApiModelProperty(value = "销量排序")
    private String buyCountSort;

    @ApiModelProperty(value = "最新时间排序")
    private String gmtCreateSort;

    @ApiModelProperty(value = "价格排序")
    private String priceSort;
}

(2)在com/atguigu/eduservice/api编写CourseApiController

java 复制代码
@Api(description="前台课程展现")
@RestController
@RequestMapping("/eduservice/courseapi")
@CrossOrigin
public class CourseApiController {
    @Autowired
    private EduCourseService courseService;

    @ApiOperation(value = "带条件分页查询课程列表")
    @PostMapping("getFrontCourseList/{current}/{limit}")
    public R getTeacherPageVo(@PathVariable Long current,
                              @PathVariable Long limit,
                              @RequestBody CourseQueryVo courseQueryVo){
        Page<EduCourse> page = new Page<>(current,limit);
        Map<String,Object> map = courseService.getCoursePageList(page,courseQueryVo);
        return R.ok().data(map);
    }  
}

(3)在EduCourseService中添加带条件分页查询课程列表 接口

java 复制代码
Map<String, Object> getCoursePageList(Page<EduCourse> page, CourseQueryVo courseQueryVo);

(4)在EduCourseServiceImpl中实现接口的方法

java 复制代码
//带条件分页查询课程列表(前台)
@Override
public Map<String, Object> getCoursePageList(Page<EduCourse> pageParam, CourseQueryVo courseQueryVo) {
    //1取出查询条件
    String subjectParentId = courseQueryVo.getSubjectParentId();//一级分类
    String subjectId = courseQueryVo.getSubjectId();//二级分类
    String buyCountSort = courseQueryVo.getBuyCountSort();//关注度
    String priceSort = courseQueryVo.getPriceSort();//价格
    String gmtCreateSort = courseQueryVo.getGmtCreateSort();//时间

    //2条件判断
    QueryWrapper<EduCourse> wrapper = new QueryWrapper<>();
    if(!StringUtils.isEmpty(subjectParentId)){
        wrapper.eq("subject_parent_id",subjectParentId);
    }
    if(!StringUtils.isEmpty(subjectId)){
        wrapper.eq("subject_id",subjectId);
    }
    if(!StringUtils.isEmpty(buyCountSort)){
        wrapper.orderByDesc("buy_count");
    }
    if(!StringUtils.isEmpty(priceSort)){
        wrapper.orderByDesc("price");
    }
    if(!StringUtils.isEmpty(gmtCreateSort)){
        wrapper.orderByDesc("gmt_create");
    }
    //3查询数据
    baseMapper.selectPage(pageParam,wrapper);
    //4封装数据
    List<EduCourse> records = pageParam.getRecords();
    long current = pageParam.getCurrent();
    long pages = pageParam.getPages();
    long size = pageParam.getSize();
    long total = pageParam.getTotal();
    boolean hasNext = pageParam.hasNext();
    boolean hasPrevious = pageParam.hasPrevious();

    Map<String, Object> map = new HashMap<String, Object>();
    map.put("items", records);
    map.put("current", current);
    map.put("pages", pages);
    map.put("size", size);
    map.put("total", total);
    map.put("hasNext", hasNext);
    map.put("hasPrevious", hasPrevious);

    return map;
}
相关推荐
A-Jie-Y8 分钟前
JAVA设计模式-抽象工厂模式
java·设计模式
@insist12320 分钟前
信息安全工程师-密码学专题(下):构建可信网络空间的核心机制
java·大数据·密码学·软考·信息安全工程师·软件水平考试
无厚25 分钟前
Spring Boot中LLM流式交互的核心原理
后端·设计
摇滚侠29 分钟前
Java 零基础全套视频教程,面向对象(高级),笔记 105-120
java·开发语言·笔记
叶落阁主37 分钟前
Spring Boot 4 实战:Jackson 2.x 升级到 3.x 踩坑全记录
java·后端·架构
布吉岛的石头38 分钟前
Java 中高级面试:JVM 内存模型 + GC 算法高频题总结
java·jvm·面试
Jump 不二1 小时前
揭秘腾讯 Ima 知识库架构:从开源 WeKnora 看 RAG + 知识图谱落地实践
人工智能·语言模型·架构·机器人·开源·知识图谱
鹏子训1 小时前
六个典型热门AI记忆架构对比:Mem0,Letta,MemoryLake,ZenBrain,MIA,MSA 助你快速选型
人工智能·架构·长短时记忆网络
2301_792674861 小时前
java学习(day32)
java