feat(video): 新增视频评价功能及购买状态查询

- 移除TaskController上的@Deprecated注解
- 在VideoController中新增/checkBuyStatus接口用于查询视频购买状态
- 新增VideoReviewController控制器,提供评价管理功能
- 新增MapTypeHandler用于处理Map类型与JSON字段的转换
- 在VideoMapper中增加countBuyRecordByVideoId方法查询视频购买记录
- 新增视频评价相关实体类、DTO及Mapper接口
- 实现VideoReviewService服务类,支持评价新增、分页查询、统计分析和Excel导出
- 在VideoServiceImpl中实现checkVideoBuyStatus方法
- 修改VideoMapper.xml,关联task表并查询task_params字段
- 新增VideoReviewMapper.xml配置文件,实现评价相关SQL查询
This commit is contained in:
2025-11-17 23:37:04 +08:00
parent ebf05ab189
commit 755ba1153e
18 changed files with 1057 additions and 5 deletions

View File

@@ -17,5 +17,12 @@ public interface VideoService {
ApiResponse<List<VideoRespVO>> list(VideoReqQuery videoReqQuery);
ApiResponse<VideoRespVO> getById(Long id);
/**
* 查询视频是否被购买
*
* @param videoId 视频ID
* @return 是否已购买 (true-已购买, false-未购买)
*/
Boolean checkVideoBuyStatus(Long videoId);
}

View File

@@ -2,7 +2,10 @@ package com.ycwl.basic.service.pc.impl;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.ycwl.basic.exception.BaseException;
import com.ycwl.basic.exception.BizException;
import com.ycwl.basic.mapper.VideoMapper;
import com.ycwl.basic.model.pc.video.entity.VideoEntity;
import com.ycwl.basic.model.pc.video.req.VideoReqQuery;
import com.ycwl.basic.model.pc.video.resp.VideoRespVO;
import com.ycwl.basic.repository.ScenicRepository;
@@ -79,4 +82,12 @@ public class VideoServiceImpl implements VideoService {
return ApiResponse.success(videoMapper.getById(id));
}
@Override
public Boolean checkVideoBuyStatus(Long videoId) {
// 查询 member_video 表中是否存在该视频的已购买记录
int count = videoMapper.countBuyRecordByVideoId(videoId);
// count > 0 表示存在已购买记录
return count > 0;
}
}