From 98019c8438f08a52466a92144e50492730b7aacb Mon Sep 17 00:00:00 2001 From: wenyu441069198 <14186472+wenyu441069198@user.noreply.gitee.com> Date: Tue, 11 Jun 2024 20:05:52 +0800 Subject: [PATCH] =?UTF-8?q?=E5=AD=A6=E4=B9=A0=E8=AE=B0=E5=BD=95init?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pom.xml | 7 - .../records/LearningRecordsController.java | 173 ++++----- .../mapper/records/LearningRecordsMapper.java | 31 +- .../model/entity/records/LearningRecords.java | 192 ++++----- .../model/vo/records/LearningRecordsVo.java | 104 ++--- .../records/LearningRecordsServiceImpl.java | 364 +++++++++--------- .../records/LearningRecordsService.java | 38 +- 7 files changed, 449 insertions(+), 460 deletions(-) diff --git a/pom.xml b/pom.xml index 71efd32..a96b610 100644 --- a/pom.xml +++ b/pom.xml @@ -155,13 +155,6 @@ spring-boot-starter-data-redis - - - - - - - diff --git a/src/main/java/com/teaching/backend/controller/records/LearningRecordsController.java b/src/main/java/com/teaching/backend/controller/records/LearningRecordsController.java index 20aaed3..5af486c 100644 --- a/src/main/java/com/teaching/backend/controller/records/LearningRecordsController.java +++ b/src/main/java/com/teaching/backend/controller/records/LearningRecordsController.java @@ -1,89 +1,84 @@ -//package com.teaching.backend.controller.records; -// -// -//import com.github.pagehelper.PageHelper; -//import com.github.pagehelper.PageInfo; -//import com.teaching.backend.common.BaseResponse; -//import com.teaching.backend.common.ResultUtils; -// -//import com.teaching.backend.model.entity.records.LearningRecords; -//import com.teaching.backend.model.vo.records.LearningRecordsVo; -//import com.teaching.backend.service.impl.records.LearningRecordsServiceImpl; -//import org.springframework.beans.factory.annotation.Autowired; -//import org.springframework.ui.Model; -//import org.springframework.web.bind.annotation.*; -// -//import java.util.ArrayList; -//import java.util.List; -// -//@RestController -//@RequestMapping("/learningrecords") -//public class LearningRecordsController { -// -// @Autowired -// private LearningRecordsServiceImpl learningRecordsService; -// -// -// /** -// * 获取当前登录用户的学习记录 -// * @param m -// * @param pagenum -// * @param pagesize -// * @return -// */ -// @GetMapping("/getall") -// public BaseResponse getAll(Model m, -// @RequestParam(value = "pagenum", defaultValue = "1") int pagenum, -// @RequestParam(value = "pagesize", defaultValue = "15") int pagesize, -// @RequestParam String userId){ -// PageHelper.startPage(pagenum,pagesize); -// List cs= learningRecordsService.getAll(userId); -// List pageCs = new ArrayList<>(); -// //当前页面 -// for(int i = (pagenum - 1) * pagesize; i < cs.size() && i < (pagenum) * pagesize; i++){ -// pageCs.add(cs.get(i)); -// } -// PageInfo pageInfo = new PageInfo<>(pageCs); -// System.out.println("当前页面:"+pagenum); -// System.out.println("当前页面大小:"+pagesize); -// System.out.println("当前页面内容:"+pageCs); -//// PageInfo pageInfo = new PageInfo<>(cs); -//// pageInfo.setPageSize(pagesize);//设置当前页面大小 -//// pageInfo.setPageNum(pagenum);//设置当前页码 -//// pageInfo.setSize(pagesize);//不知道是啥,--------- -//// pageInfo.setTotal(cs.size());//设置总条数 -// long total = pageInfo.getTotal(); // 总记录数 -//// pageInfo.setPages((int)(Math.ceil((double) total / pagesize)));//设置总页数 -// return ResultUtils.success(pageInfo); -// } -// -// @GetMapping("/all") -// public BaseResponse> All(){ -// System.out.println("学习记录:"+learningRecordsService.list()); -// return ResultUtils.success(learningRecordsService.list()); -// } -// -// //资源类型: 1,课程学习记录,2,知识点学习记录,3课程资源学习记录 -// /** -// * 添加课程记录 -// * @param learningRecords -// * @return -// */ -// @PostMapping("/saverecords") -// public BaseResponse saveRecords(@RequestBody LearningRecords learningRecords){ -// System.out.println(learningRecords); -// return ResultUtils.success(learningRecordsService.saveRecords(learningRecords)); -// } -// -// /** -// * 根据id删除 -// * @param ids -// * @return -// */ -// @DeleteMapping("/delete") -// public BaseResponse deleteRecords(@RequestParam List ids){ -// -// return ResultUtils.success(learningRecordsService.delete(ids)); -// } -// -//} +package com.teaching.backend.controller.records; + + +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ResultUtils; + +import com.teaching.backend.model.entity.records.LearningRecords; +import com.teaching.backend.model.vo.records.LearningRecordsVo; +import com.teaching.backend.service.impl.records.LearningRecordsServiceImpl; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.ui.Model; +import org.springframework.web.bind.annotation.*; + +import java.util.ArrayList; +import java.util.List; + +@RestController +@RequestMapping("/learningrecords") +public class LearningRecordsController { + + @Autowired + private LearningRecordsServiceImpl learningRecordsService; + + + /** + * 获取当前登录用户的学习记录 + * @param pagenum + * @param pagesize + * @return + */ + @GetMapping("/getall") + public BaseResponse getAll(@RequestParam(value = "pagenum", defaultValue = "1") int pagenum, + @RequestParam(value = "pagesize", defaultValue = "15") int pagesize, + @RequestParam String userId){ + List cs= learningRecordsService.getAll(userId); + List pageCs = new ArrayList<>(); + //当前页面 + for(int i = (pagenum - 1) * pagesize; i < cs.size() && i < (pagenum) * pagesize; i++){ + pageCs.add(cs.get(i)); + } + long total = cs.size(); // 总记录数 + Page pageInfo = new Page<>(pagenum,pagesize,total); + pageInfo.setRecords(pageCs); + System.out.println("总记录数"+pageInfo.getTotal()); + System.out.println("当前页面:"+pagenum); + System.out.println("当前页面大小:"+pagesize); + System.out.println("当前页面内容:"+pageCs); + System.out.println("页面数:"+pageInfo.getPages()); + pageInfo.setPages((int)(Math.ceil((double) total / pagesize)));//设置总页数 + System.out.println(pageInfo.getPages()); + return ResultUtils.success(pageInfo); + } + + @GetMapping("/all") + public BaseResponse> All(){ + System.out.println("学习记录:"+learningRecordsService.list()); + return ResultUtils.success(learningRecordsService.list()); + } + + //资源类型: 1,课程学习记录,2,知识点学习记录,3课程资源学习记录 + /** + * 添加课程记录 + * @param learningRecords + * @return + */ + @PostMapping("/saverecords") + public BaseResponse saveRecords(@RequestBody LearningRecords learningRecords){ + System.out.println(learningRecords); + return ResultUtils.success(learningRecordsService.saveRecords(learningRecords)); + } + + /** + * 根据id删除 + * @param ids + * @return + */ + @DeleteMapping("/delete") + public BaseResponse deleteRecords(@RequestParam List ids){ + + return ResultUtils.success(learningRecordsService.delete(ids)); + } + +} diff --git a/src/main/java/com/teaching/backend/mapper/records/LearningRecordsMapper.java b/src/main/java/com/teaching/backend/mapper/records/LearningRecordsMapper.java index cf6f3d1..fe107ef 100644 --- a/src/main/java/com/teaching/backend/mapper/records/LearningRecordsMapper.java +++ b/src/main/java/com/teaching/backend/mapper/records/LearningRecordsMapper.java @@ -1,16 +1,17 @@ -//package com.teaching.backend.mapper.records; +package com.teaching.backend.mapper.records; + + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.teaching.backend.model.entity.records.LearningRecords; +import org.apache.ibatis.annotations.Mapper; +import org.apache.ibatis.annotations.Param; + +@Mapper +public interface LearningRecordsMapper extends BaseMapper { + IPage selectPageList(Page page, @Param("model")LearningRecords model); + +} // -//import com.baomidou.mybatisplus.core.mapper.BaseMapper; -//import com.baomidou.mybatisplus.core.metadata.IPage; -//import com.baomidou.mybatisplus.extension.plugins.pagination.Page; -// -//import com.teaching.backend.model.entity.records.LearningRecords; -//import org.apache.ibatis.annotations.Mapper; -//import org.apache.ibatis.annotations.Param; -// -//@Mapper -//public interface LearningRecordsMapper extends BaseMapper { -// IPage selectPageList(Page page, @Param("model")LearningRecords model); -// -//} -//// diff --git a/src/main/java/com/teaching/backend/model/entity/records/LearningRecords.java b/src/main/java/com/teaching/backend/model/entity/records/LearningRecords.java index 37cd5ef..be7d920 100644 --- a/src/main/java/com/teaching/backend/model/entity/records/LearningRecords.java +++ b/src/main/java/com/teaching/backend/model/entity/records/LearningRecords.java @@ -1,96 +1,96 @@ -//package com.teaching.backend.model.entity.records; -// -// -//import com.baomidou.mybatisplus.annotation.IdType; -//import com.baomidou.mybatisplus.annotation.TableId; -//import com.baomidou.mybatisplus.annotation.TableName; -//import lombok.Data; -//import lombok.EqualsAndHashCode; -//import lombok.experimental.Accessors; -// -//import java.time.LocalDateTime; -// -// -//@Data -//@EqualsAndHashCode(callSuper = false) -//@Accessors(chain = true) -//@TableName("learning_records") -//public class LearningRecords { -// private static final long serialVersionUID = 1L; -// -// /** -// * 内部编号 -// */ -// @TableId(value = "id", type = IdType.ASSIGN_ID) -// private String id; -// -// /** -// * 用户id -// */ -// private String userId; -// -// /** -// * 课程id -// */ -// private String coursesId; -// /** -// * 章节id -// */ -// private String chapterId; -// /** -// * 知识点id -// */ -// private String knowledgePointId; -// /** -// * 资源id -// */ -// private String resourceId; -// /** -// * 访问时间 -// */ -// private LocalDateTime accessTime; -// -// /** -// * 学习方式:打开; 1,打开过,2未打开 -// */ -// private String learningMethod1; -// /** -// * 学习方式:下载; 1下载过, 2未下载 -// */ -// private String learningMethod2; -// /** -// *视频学习时长 -// */ -// private String videoDuration; -// -// /** -// *是否完成观看:1,已完成,0未完成 -// */ -// private String isCompleted; -// -// /** -// * 记录封面图片 -// */ -// private String content; -// /** -// * 资源地址 -// */ -// private String address; -// -// /** -// * 是否存在: 1存在;0不存在; -// */ -// private String status; -// /** -// * 类型, 如:1,课程; 2,章节; 3,知识点; 4,学习资源 -// */ -// private String type; -// /** -// * 父节点 -// */ -// private String parentNode; -// -// -// -// -//} +package com.teaching.backend.model.entity.records; + + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; +import lombok.EqualsAndHashCode; +import lombok.experimental.Accessors; + +import java.time.LocalDateTime; + + +@Data +@EqualsAndHashCode(callSuper = false) +@Accessors(chain = true) +@TableName("learning_records") +public class LearningRecords { + private static final long serialVersionUID = 1L; + + /** + * 内部编号 + */ + @TableId(value = "id", type = IdType.ASSIGN_ID) + private String id; + + /** + * 用户id + */ + private String userId; + + /** + * 课程id + */ + private String coursesId; + /** + * 章节id + */ + private String chapterId; + /** + * 知识点id + */ + private String knowledgePointId; + /** + * 资源id + */ + private String resourceId; + /** + * 访问时间 + */ + private LocalDateTime accessTime; + + /** + * 学习方式:打开; 1,打开过,2未打开 + */ + private String learningMethod1; + /** + * 学习方式:下载; 1下载过, 2未下载 + */ + private String learningMethod2; + /** + *视频学习时长 + */ + private String videoDuration; + + /** + *是否完成观看:1,已完成,0未完成 + */ + private String isCompleted; + + /** + * 记录封面图片 + */ + private String content; + /** + * 资源地址 + */ + private String address; + + /** + * 是否存在: 1存在;0不存在; + */ + private String status; + /** + * 类型, 如:1,课程; 2,章节; 3,知识点; 4,学习资源 + */ + private String type; + /** + * 父节点 + */ + private String parentNode; + + + + +} diff --git a/src/main/java/com/teaching/backend/model/vo/records/LearningRecordsVo.java b/src/main/java/com/teaching/backend/model/vo/records/LearningRecordsVo.java index 75b2550..e9b3ab2 100644 --- a/src/main/java/com/teaching/backend/model/vo/records/LearningRecordsVo.java +++ b/src/main/java/com/teaching/backend/model/vo/records/LearningRecordsVo.java @@ -1,59 +1,59 @@ -//package com.teaching.backend.model.vo.records; -// -//import lombok.Data; -//import lombok.EqualsAndHashCode; -//import lombok.experimental.Accessors; -// -//@Data -//@EqualsAndHashCode(callSuper = false) -//@Accessors(chain = true) -//public class LearningRecordsVo { -//// private static final long serialVersionUID = 1L; -// +package com.teaching.backend.model.vo.records; + +import lombok.Data; +import lombok.EqualsAndHashCode; +import lombok.experimental.Accessors; + +@Data +@EqualsAndHashCode(callSuper = false) +@Accessors(chain = true) +public class LearningRecordsVo { +// private static final long serialVersionUID = 1L; + + /** + * 内部编号 + */ + private String id; + + /** + * 课程名称 + */ + private String coursesName; + // /** -// * 内部编号 +// * 资源类型 // */ -// private String id; -// +// private String type; + + /** + * 封面 + */ + private String content; + + /** + * 资源观看人数 + */ + private Long number; + + + /** + * 上次观看时间 + */ + private String time; + /** + * 地址 + */ + private String address; // /** -// * 课程名称 +// * 创建日期 // */ -// private String coursesName; -// -//// /** -//// * 资源类型 -//// */ -//// private String type; +// private LocalDateTime createTime; // // /** -// * 封面 +// * 更新日期 // */ -// private String content; -// -// /** -// * 资源观看人数 -// */ -// private Long number; -// -// -// /** -// * 上次观看时间 -// */ -// private String time; -// /** -// * 地址 -// */ -// private String address; -//// /** -//// * 创建日期 -//// */ -//// private LocalDateTime createTime; -//// -//// /** -//// * 更新日期 -//// */ -//// private LocalDateTime updateTime; -// -// -// -//} +// private LocalDateTime updateTime; + + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/records/LearningRecordsServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/records/LearningRecordsServiceImpl.java index ba5473d..9bf49af 100644 --- a/src/main/java/com/teaching/backend/service/impl/records/LearningRecordsServiceImpl.java +++ b/src/main/java/com/teaching/backend/service/impl/records/LearningRecordsServiceImpl.java @@ -1,185 +1,185 @@ -//package com.teaching.backend.service.impl.records; -// -//import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; -//import com.baomidou.mybatisplus.core.metadata.IPage; -//import com.baomidou.mybatisplus.extension.plugins.pagination.Page; -//import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -// -//import com.teaching.backend.mapper.records.LearningRecordsMapper; -// -//import com.teaching.backend.model.entity.records.LearningRecords; -//import com.teaching.backend.model.vo.records.LearningRecordsVo; -//import com.teaching.backend.service.impl.chapter.ChapterServiceImpl; -//import com.teaching.backend.service.impl.courses.CoursesServiceImpl; -//import com.teaching.backend.service.impl.know.IknowServiceimpl; -//import com.teaching.backend.service.records.LearningRecordsService; -//import org.springframework.beans.BeanUtils; -//import org.springframework.beans.factory.annotation.Autowired; -//import org.springframework.stereotype.Service; -// -//import java.text.SimpleDateFormat; -//import java.time.LocalDateTime; -//import java.time.ZoneId; -//import java.util.ArrayList; -//import java.util.Date; -//import java.util.List; -// -//@Service -//public class LearningRecordsServiceImpl extends ServiceImpl implements LearningRecordsService { -// -// @Autowired -// private CoursesServiceImpl coursesService; +package com.teaching.backend.service.impl.records; + +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; + +import com.teaching.backend.mapper.records.LearningRecordsMapper; + +import com.teaching.backend.model.entity.records.LearningRecords; +import com.teaching.backend.model.vo.records.LearningRecordsVo; +import com.teaching.backend.service.impl.chapter.ChapterServiceImpl; +import com.teaching.backend.service.impl.courses.CoursesServiceImpl; +import com.teaching.backend.service.impl.know.IknowServiceimpl; +import com.teaching.backend.service.records.LearningRecordsService; +import org.springframework.beans.BeanUtils; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import java.text.SimpleDateFormat; +import java.time.LocalDateTime; +import java.time.ZoneId; +import java.util.ArrayList; +import java.util.Date; +import java.util.List; + +@Service +public class LearningRecordsServiceImpl extends ServiceImpl implements LearningRecordsService { + + @Autowired + private CoursesServiceImpl coursesService; + @Autowired + private LearningRecordsMapper learningRecordsMapper; // @Autowired -// private LearningRecordsMapper learningRecordsMapper; -//// @Autowired -//// private LearningResourceServiceImpl learningResourceService; -// @Autowired -// private IknowServiceimpl knowledgePointService; -// @Autowired -// private ChapterServiceImpl chapterService; -// -// @Override -// public IPage selectPageList(Page page, LearningRecords model) { -// return learningRecordsMapper.selectPageList(page,model); -// } -// -// @Override -// public String delete(List ids) { -// LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); -// lambdaQueryWrapper.in(LearningRecords::getId, ids); -// List list = this.list(lambdaQueryWrapper); -// //把即将要删除的记录状态调成0 -// for (LearningRecords learningRecords : list) { -// learningRecords.setStatus("0"); -// } -// this.updateBatchById(list); -//// System.out.println(this.updateBatchById(list)); -//// this.remove(lambdaQueryWrapper); -// return "删除成功"; -// } -// -// @Override -// public List getAll(String userId){ -// //格式化时间 -// //格式化时间 -// String strDateFormat = "yyyy-MM-dd HH:mm:ss"; -// SimpleDateFormat sdf = new SimpleDateFormat(strDateFormat); -// -// List list = new ArrayList<>(); -// //将学习记录实体转成学习记录Vo实体 -// LambdaQueryWrapper lambdaQueryWrapper1 = new LambdaQueryWrapper<>(); -// lambdaQueryWrapper1 -// .orderByDesc(LearningRecords::getAccessTime) -// .eq(LearningRecords::getUserId, userId) -// .eq(LearningRecords::getStatus, "1"); -// System.out.println(this.list(lambdaQueryWrapper1)); -// //如果为空-------------------????? -// for (LearningRecords learningRecords : this.list(lambdaQueryWrapper1)) { -// //查找该用户的学习记录 -//// if (learningRecords.getUserId().equals(userId) && learningRecords.getStatus().equals("1")){ -// LearningRecordsVo learningRecordsVo = new LearningRecordsVo();//好像可以拿出去-----------?? -// BeanUtils.copyProperties(learningRecords,learningRecordsVo);//从多传到少(缺少人数,和资源名称,时间需要转格式) -// //添加时间 -// //LocalDateTime转Date -// Date date = Date.from(learningRecords.getAccessTime().atZone(ZoneId.systemDefault()).toInstant()); -// learningRecordsVo.setTime(sdf.format(date)); -// LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); -// lambdaQueryWrapper.eq(LearningRecords::getCoursesId, learningRecords.getCoursesId()); -//// System.out.println(learningRecords.getResourceId()); -//// System.out.println("1"); -// -// //添加课程名称 -// switch (learningRecords.getType()) { -// case "4": //如果是资源学习 -// learningRecordsVo.setCoursesName("学习资源");//设置名称 --------------------------------------------待完善 -// -// break; -// case "3": //如果是知识点学习记录 -// learningRecordsVo.setCoursesName(knowledgePointService.getById(learningRecords.getCoursesId()).getName()); -// -// break; -// case "2": //如果是章节学习记录 -// learningRecordsVo.setCoursesName(chapterService.getById(learningRecords.getCoursesId()).getName()); -// -// break; -// case "1": //如果是课程学习记录 -// learningRecordsVo.setCoursesName(coursesService.getById(learningRecords.getCoursesId()).getName()); -// break; -// } -// //添加观看人数 -// //统计记录表里有多少人查看过这门资源 -// long count = this.count(lambdaQueryWrapper); -// System.out.println(count); -// learningRecordsVo.setNumber(count); -// //把整合后该用户的学习记录添加到List里 -// list.add(learningRecordsVo); -//// } -// } -// System.out.println(list); -// return list; -// } -// -// /** -// * 根据用户id和学习资源id来判断记录是否存在 -// * @param learningRecords -// * @return -// */ -// @Override -// public String saveRecords(LearningRecords learningRecords) { -// String userId = learningRecords.getUserId(); -// String coursesId = learningRecords.getCoursesId(); -// System.out.println("学习记录:"+learningRecords); -// //查找该用户是否观看过该学习资源 -// LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); -// lambdaQueryWrapper -// .eq(LearningRecords::getUserId, userId) -// .eq(LearningRecords::getCoursesId, coursesId) -// .eq(LearningRecords::getType, learningRecords.getType()); -// long count = this.count(lambdaQueryWrapper); -// System.out.println("数据库:"+count); -// learningRecords.setStatus("1");//将该记录的状态设置为1 -// //更新观看时间 -// learningRecords.setAccessTime(LocalDateTime.now()); -// //设置默认封面 -// if (learningRecords.getContent() == null || learningRecords.getContent().equals("")){ -// learningRecords.setContent("https://teaching-edu123.oss-cn-beijing.aliyuncs.com/Borovets_ZH-CN5914681811_UHD.jpg"); -// } -//// //添加记录封面 -//// switch (learningRecords.getType()) { -//// case "4": //如果是资源学习 -//// learningRecords.setContent(learningResourceService.getById(learningRecords.getCoursesId()).getContent());//设置封面 -//// break; -//// case "3": //如果是知识点学习记录 -//// learningRecords.setContent(knowledgePointService.getById(learningRecords.getCoursesId()).getContent());//设置封面 -//// -//// break; -//// case "2": //如果是章节学习记录 -//// learningRecords.setContent(chapterService.getById(learningRecords.getCoursesId()).getContent());//设置封面 -//// -//// break; -//// case "1": //如果是课程学习记录 -//// learningRecords.setContent(coursesService.getById(learningRecords.getCoursesId()).getImg());//设置封面 -//// break; -//// } -// if (count == 0){//如果没有就新增并记录学习方式是打开还是下载 -// //根据传上来的type设置 -//// learningRecords.setType(learningRecords.getType()); -// this.save(learningRecords); -// return "添加成功"; -// }else {//有就修改记录,更新学习方式 -// LearningRecords one = this.getOne(lambdaQueryWrapper); -// System.out.println(one); -// learningRecords.setId(one.getId());//找到该条记录的id并赋值给本次观看记录 -// if ( one.getLearningMethod1() != null && one.getLearningMethod1().equals("1")){ -// learningRecords.setLearningMethod1(one.getLearningMethod1()); +// private LearningResourceServiceImpl learningResourceService; + @Autowired + private IknowServiceimpl knowledgePointService; + @Autowired + private ChapterServiceImpl chapterService; + + @Override + public IPage selectPageList(Page page, LearningRecords model) { + return learningRecordsMapper.selectPageList(page,model); + } + + @Override + public String delete(List ids) { + LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); + lambdaQueryWrapper.in(LearningRecords::getId, ids); + List list = this.list(lambdaQueryWrapper); + //把即将要删除的记录状态调成0 + for (LearningRecords learningRecords : list) { + learningRecords.setStatus("0"); + } + this.updateBatchById(list); +// System.out.println(this.updateBatchById(list)); +// this.remove(lambdaQueryWrapper); + return "删除成功"; + } + + @Override + public List getAll(String userId){ + //格式化时间 + //格式化时间 + String strDateFormat = "yyyy-MM-dd HH:mm:ss"; + SimpleDateFormat sdf = new SimpleDateFormat(strDateFormat); + + List list = new ArrayList<>(); + //将学习记录实体转成学习记录Vo实体 + LambdaQueryWrapper lambdaQueryWrapper1 = new LambdaQueryWrapper<>(); + lambdaQueryWrapper1 + .orderByDesc(LearningRecords::getAccessTime) + .eq(LearningRecords::getUserId, userId) + .eq(LearningRecords::getStatus, "1"); + System.out.println(this.list(lambdaQueryWrapper1)); + //如果为空-------------------????? + for (LearningRecords learningRecords : this.list(lambdaQueryWrapper1)) { + //查找该用户的学习记录 +// if (learningRecords.getUserId().equals(userId) && learningRecords.getStatus().equals("1")){ + LearningRecordsVo learningRecordsVo = new LearningRecordsVo();//好像可以拿出去-----------?? + BeanUtils.copyProperties(learningRecords,learningRecordsVo);//从多传到少(缺少人数,和资源名称,时间需要转格式) + //添加时间 + //LocalDateTime转Date + Date date = Date.from(learningRecords.getAccessTime().atZone(ZoneId.systemDefault()).toInstant()); + learningRecordsVo.setTime(sdf.format(date)); + LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); + lambdaQueryWrapper.eq(LearningRecords::getCoursesId, learningRecords.getCoursesId()); +// System.out.println(learningRecords.getResourceId()); +// System.out.println("1"); + + //添加课程名称 + switch (learningRecords.getType()) { + case "4": //如果是资源学习 + learningRecordsVo.setCoursesName("学习资源");//设置名称 --------------------------------------------待完善 + + break; + case "3": //如果是知识点学习记录 + learningRecordsVo.setCoursesName(knowledgePointService.getById(learningRecords.getCoursesId()).getName()); + + break; + case "2": //如果是章节学习记录 + learningRecordsVo.setCoursesName(chapterService.getById(learningRecords.getCoursesId()).getName()); + + break; + case "1": //如果是课程学习记录 + learningRecordsVo.setCoursesName(coursesService.getById(learningRecords.getCoursesId()).getName()); + break; + } + //添加观看人数 + //统计记录表里有多少人查看过这门资源 + long count = this.count(lambdaQueryWrapper); + System.out.println(count); + learningRecordsVo.setNumber(count); + //把整合后该用户的学习记录添加到List里 + list.add(learningRecordsVo); // } -// if (one.getLearningMethod2() != null && one.getLearningMethod2().equals("1")){ -// learningRecords.setLearningMethod2(one.getLearningMethod2()); -// } -// this.updateById(learningRecords); -// return "修改成功"; + } + System.out.println(list); + return list; + } + + /** + * 根据用户id和学习资源id来判断记录是否存在 + * @param learningRecords + * @return + */ + @Override + public String saveRecords(LearningRecords learningRecords) { + String userId = learningRecords.getUserId(); + String coursesId = learningRecords.getCoursesId(); + System.out.println("学习记录:"+learningRecords); + //查找该用户是否观看过该学习资源 + LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); + lambdaQueryWrapper + .eq(LearningRecords::getUserId, userId) + .eq(LearningRecords::getCoursesId, coursesId) + .eq(LearningRecords::getType, learningRecords.getType()); + long count = this.count(lambdaQueryWrapper); + System.out.println("数据库:"+count); + learningRecords.setStatus("1");//将该记录的状态设置为1 + //更新观看时间 + learningRecords.setAccessTime(LocalDateTime.now()); + //设置默认封面 + if (learningRecords.getContent() == null || learningRecords.getContent().equals("")){ + learningRecords.setContent("https://teaching-edu123.oss-cn-beijing.aliyuncs.com/Borovets_ZH-CN5914681811_UHD.jpg"); + } +// //添加记录封面 +// switch (learningRecords.getType()) { +// case "4": //如果是资源学习 +// learningRecords.setContent(learningResourceService.getById(learningRecords.getCoursesId()).getContent());//设置封面 +// break; +// case "3": //如果是知识点学习记录 +// learningRecords.setContent(knowledgePointService.getById(learningRecords.getCoursesId()).getContent());//设置封面 +// +// break; +// case "2": //如果是章节学习记录 +// learningRecords.setContent(chapterService.getById(learningRecords.getCoursesId()).getContent());//设置封面 +// +// break; +// case "1": //如果是课程学习记录 +// learningRecords.setContent(coursesService.getById(learningRecords.getCoursesId()).getImg());//设置封面 +// break; // } -// } -// -// -//} + if (count == 0){//如果没有就新增并记录学习方式是打开还是下载 + //根据传上来的type设置 +// learningRecords.setType(learningRecords.getType()); + this.save(learningRecords); + return "添加成功"; + }else {//有就修改记录,更新学习方式 + LearningRecords one = this.getOne(lambdaQueryWrapper); + System.out.println(one); + learningRecords.setId(one.getId());//找到该条记录的id并赋值给本次观看记录 + if ( one.getLearningMethod1() != null && one.getLearningMethod1().equals("1")){ + learningRecords.setLearningMethod1(one.getLearningMethod1()); + } + if (one.getLearningMethod2() != null && one.getLearningMethod2().equals("1")){ + learningRecords.setLearningMethod2(one.getLearningMethod2()); + } + this.updateById(learningRecords); + return "修改成功"; + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/records/LearningRecordsService.java b/src/main/java/com/teaching/backend/service/records/LearningRecordsService.java index daa776a..d2acb1b 100644 --- a/src/main/java/com/teaching/backend/service/records/LearningRecordsService.java +++ b/src/main/java/com/teaching/backend/service/records/LearningRecordsService.java @@ -1,19 +1,19 @@ -//package com.teaching.backend.service.records; -// -//import com.baomidou.mybatisplus.core.metadata.IPage; -//import com.baomidou.mybatisplus.extension.plugins.pagination.Page; -//import com.baomidou.mybatisplus.extension.service.IService; -//import com.teaching.backend.model.entity.records.LearningRecords; -//import com.teaching.backend.model.vo.records.LearningRecordsVo; -// -// -//import java.util.List; -// -//public interface LearningRecordsService extends IService { -// public List getAll(String username); -// public String saveRecords(LearningRecords learningRecords); -// IPage selectPageList(Page page, LearningRecords model); -// -// public String delete(List ids); -// -//} +package com.teaching.backend.service.records; + +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.records.LearningRecords; +import com.teaching.backend.model.vo.records.LearningRecordsVo; + + +import java.util.List; + +public interface LearningRecordsService extends IService { + public List getAll(String username); + public String saveRecords(LearningRecords learningRecords); + IPage selectPageList(Page page, LearningRecords model); + + public String delete(List ids); + +}