更新
This commit is contained in:
parent
4316b10fde
commit
2222d0430c
@ -0,0 +1,34 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.controller.admin;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
||||||
|
import cn.iocoder.yudao.module.base.entity.DriveSchoolCourseDeduct;
|
||||||
|
import cn.iocoder.yudao.module.base.service.DlDriveSchoolCourseDeductService;
|
||||||
|
import cn.iocoder.yudao.module.base.vo.DriveSchoolCourseDeductVO;
|
||||||
|
import com.github.pagehelper.Page;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/base/drive-school-course-deduct")
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
public class DlDriveSchoolCourseDeductController {
|
||||||
|
|
||||||
|
private final DlDriveSchoolCourseDeductService driveSchoolCourseDeductService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分页查询
|
||||||
|
*
|
||||||
|
* @param request @class DriveSchoolCourseDeductVO
|
||||||
|
* @param pageNo 页码
|
||||||
|
* @param pageSize 每页条数
|
||||||
|
* @return @class DriveSchoolCourseDeductVO
|
||||||
|
*/
|
||||||
|
public CommonResult<?> page(DriveSchoolCourseDeductVO request,
|
||||||
|
@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo,
|
||||||
|
@RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
|
||||||
|
Page<DriveSchoolCourseDeductVO> page = new Page<>(pageNo, pageSize);
|
||||||
|
return CommonResult.success(driveSchoolCourseDeductService.queryPage(page, request));
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,34 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.entity;
|
||||||
|
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.annotation.Excel;
|
||||||
|
import cn.iocoder.yudao.framework.tenant.core.db.TenantBaseDO;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 提成配置对象 drive_school_course_deduct
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2024-05-07
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
public class DriveSchoolCourseDeduct extends TenantBaseDO
|
||||||
|
{
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
/** 主键id */
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 提成比例 */
|
||||||
|
@Excel(name = "提成比例")
|
||||||
|
private BigDecimal deduct;
|
||||||
|
|
||||||
|
/** 科目id */
|
||||||
|
private String courseId;
|
||||||
|
|
||||||
|
/** 科目 */
|
||||||
|
@Excel(name = "科目")
|
||||||
|
private String courseSubject;
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.mapper;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.module.base.entity.DriveSchoolCourseDeduct;
|
||||||
|
import cn.iocoder.yudao.module.base.vo.DriveSchoolCourseDeductVO;
|
||||||
|
import cn.iocoder.yudao.module.jx.domain.DriveSchoolDeduct;
|
||||||
|
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
|
import com.github.pagehelper.Page;
|
||||||
|
import org.apache.ibatis.annotations.Mapper;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 提成配置Mapper接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2024-05-07
|
||||||
|
*/
|
||||||
|
@Mapper
|
||||||
|
public interface DriveSchoolCourseDeductMapper extends BaseMapper<DriveSchoolCourseDeduct>
|
||||||
|
{
|
||||||
|
IPage<DriveSchoolCourseDeductVO> queryPage(@Param("page") Page<DriveSchoolCourseDeductVO> page, @Param("request") DriveSchoolCourseDeductVO request);
|
||||||
|
}
|
@ -0,0 +1,26 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.service;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.module.base.entity.DriveSchoolCourseDeduct;
|
||||||
|
import cn.iocoder.yudao.module.base.vo.DriveSchoolCourseDeductVO;
|
||||||
|
import cn.iocoder.yudao.module.jx.domain.DriveSchoolDeduct;
|
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
|
import com.baomidou.mybatisplus.extension.service.IService;
|
||||||
|
import com.github.pagehelper.Page;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 提成配置Service接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2024-05-07
|
||||||
|
*/
|
||||||
|
public interface DlDriveSchoolCourseDeductService extends IService<DriveSchoolCourseDeduct> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分页查询提成配置
|
||||||
|
*
|
||||||
|
* @param page 分页对象
|
||||||
|
* @param request 查询参数
|
||||||
|
* @return 分页结果
|
||||||
|
*/
|
||||||
|
IPage<DriveSchoolCourseDeductVO> queryPage(Page<DriveSchoolCourseDeductVO> page, DriveSchoolCourseDeductVO request);
|
||||||
|
}
|
@ -180,7 +180,7 @@ public class DataViewServiceImpl implements DataViewService {
|
|||||||
//教练查询
|
//教练查询
|
||||||
/*1.学员情况*/
|
/*1.学员情况*/
|
||||||
List<DlDriveSchoolStudentVO> studentVOList = studentMapper.selectStudentListCoach(coachId,startTimeStr,endTimeStr);
|
List<DlDriveSchoolStudentVO> studentVOList = studentMapper.selectStudentListCoach(coachId,startTimeStr,endTimeStr);
|
||||||
int overNum = (int) studentVOList.stream().filter(item -> null != item.getGradTime()).count();
|
int overNum = (int) studentVOList.stream().filter(item -> null != item.getOrderGradTime()).count();
|
||||||
int noOverNum = studentVOList.size()-overNum;
|
int noOverNum = studentVOList.size()-overNum;
|
||||||
Map<String,Object> studentInfoMap = new HashMap<>();
|
Map<String,Object> studentInfoMap = new HashMap<>();
|
||||||
studentInfoMap.put("allNum",studentVOList.size());
|
studentInfoMap.put("allNum",studentVOList.size());
|
||||||
|
@ -0,0 +1,46 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.service.impl;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
||||||
|
import cn.iocoder.yudao.module.base.entity.DriveSchoolCourseDeduct;
|
||||||
|
import cn.iocoder.yudao.module.base.mapper.DriveSchoolCourseDeductMapper;
|
||||||
|
import cn.iocoder.yudao.module.base.service.DlDriveSchoolCourseDeductService;
|
||||||
|
import cn.iocoder.yudao.module.base.vo.DriveSchoolCourseDeductVO;
|
||||||
|
import cn.iocoder.yudao.module.jx.domain.DriveSchoolDeduct;
|
||||||
|
import cn.iocoder.yudao.module.jx.mapper.DriveSchoolDeductMapper;
|
||||||
|
import cn.iocoder.yudao.module.jx.service.IDriveSchoolDeductService;
|
||||||
|
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
||||||
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||||
|
import com.github.pagehelper.Page;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 提成配置Service业务层处理
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2024-05-07
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class DlDriveSchoolCourseDeductServiceImpl extends ServiceImpl<DriveSchoolCourseDeductMapper, DriveSchoolCourseDeduct> implements DlDriveSchoolCourseDeductService
|
||||||
|
{
|
||||||
|
@Resource
|
||||||
|
private AdminUserApi userApi;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分页查询提成配置
|
||||||
|
*
|
||||||
|
* @param page 分页对象
|
||||||
|
* @param request 查询参数
|
||||||
|
* @return 分页结果
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public IPage<DriveSchoolCourseDeductVO> queryPage(Page<DriveSchoolCourseDeductVO> page, DriveSchoolCourseDeductVO request) {
|
||||||
|
return baseMapper.queryPage(page, request);
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
package cn.iocoder.yudao.module.base.service.impl;
|
package cn.iocoder.yudao.module.base.service.impl;
|
||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.collection.CollUtil;
|
||||||
import cn.hutool.core.date.DateUtil;
|
import cn.hutool.core.date.DateUtil;
|
||||||
import cn.hutool.core.util.ObjectUtil;
|
import cn.hutool.core.util.ObjectUtil;
|
||||||
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
||||||
@ -15,6 +16,7 @@ import cn.iocoder.yudao.module.base.service.SchoolNotifyMessageSendService;
|
|||||||
import cn.iocoder.yudao.module.base.vo.DlDriveSchoolStaffVO;
|
import cn.iocoder.yudao.module.base.vo.DlDriveSchoolStaffVO;
|
||||||
import cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO;
|
import cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO;
|
||||||
import cn.iocoder.yudao.module.base.vo.StudentCountVO;
|
import cn.iocoder.yudao.module.base.vo.StudentCountVO;
|
||||||
|
import cn.iocoder.yudao.module.course.entity.Process;
|
||||||
import cn.iocoder.yudao.module.course.entity.SchoolCourseOrder;
|
import cn.iocoder.yudao.module.course.entity.SchoolCourseOrder;
|
||||||
import cn.iocoder.yudao.module.course.service.ProcessService;
|
import cn.iocoder.yudao.module.course.service.ProcessService;
|
||||||
import cn.iocoder.yudao.module.course.service.SchoolCourseOrderService;
|
import cn.iocoder.yudao.module.course.service.SchoolCourseOrderService;
|
||||||
@ -32,6 +34,7 @@ import org.springframework.transaction.annotation.Transactional;
|
|||||||
import org.springframework.validation.annotation.Validated;
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
import java.util.Comparator;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -69,7 +72,7 @@ public class DlDriveSchoolStudentServiceImpl extends ServiceImpl<DlDriveSchoolSt
|
|||||||
dlDriveSchoolStudent.setUniqueCode(uniqueCode);
|
dlDriveSchoolStudent.setUniqueCode(uniqueCode);
|
||||||
dlDriveSchoolStudentMapper.insert(dlDriveSchoolStudent);
|
dlDriveSchoolStudentMapper.insert(dlDriveSchoolStudent);
|
||||||
return dlDriveSchoolStudent.getId();
|
return dlDriveSchoolStudent.getId();
|
||||||
}else {
|
} else {
|
||||||
dlDriveSchoolStudent.setId(studentByIdCard.getId());
|
dlDriveSchoolStudent.setId(studentByIdCard.getId());
|
||||||
dlDriveSchoolStudent.setUniqueCode(studentByIdCard.getUniqueCode());
|
dlDriveSchoolStudent.setUniqueCode(studentByIdCard.getUniqueCode());
|
||||||
dlDriveSchoolStudentMapper.updateById(dlDriveSchoolStudent);
|
dlDriveSchoolStudentMapper.updateById(dlDriveSchoolStudent);
|
||||||
@ -232,7 +235,30 @@ public class DlDriveSchoolStudentServiceImpl extends ServiceImpl<DlDriveSchoolSt
|
|||||||
IPage<DlDriveSchoolStudentVO> pageResult = dlDriveSchoolStudentMapper.selectByCoachId(pageReqVO, page);
|
IPage<DlDriveSchoolStudentVO> pageResult = dlDriveSchoolStudentMapper.selectByCoachId(pageReqVO, page);
|
||||||
pageResult.getRecords().forEach(item -> {
|
pageResult.getRecords().forEach(item -> {
|
||||||
//查每个学生的当前所处的科目
|
//查每个学生的当前所处的科目
|
||||||
item.setProcess(processService.selectByUserId(item.getUserId(), item.getCoachId()));
|
List<Process> list = processService.list(Wrappers.<Process>lambdaQuery()
|
||||||
|
.eq(Process::getUserId, item.getUserId())
|
||||||
|
.eq(Process::getCoachId, item.getCoachId())
|
||||||
|
.eq(Process::getCourseId, item.getCourseId())
|
||||||
|
.orderByDesc(Process::getCreateTime));
|
||||||
|
|
||||||
|
Process newProcess = new Process();
|
||||||
|
if (CollUtil.isNotEmpty(list)) {
|
||||||
|
// 查询正在进行的课程
|
||||||
|
newProcess = list.stream().filter(process -> process.getStatus().equals("1")).findFirst().orElse(null);
|
||||||
|
if (ObjectUtil.isNotEmpty(newProcess)) {
|
||||||
|
item.setProcess(newProcess);
|
||||||
|
} else {
|
||||||
|
// 判断所有进度是否都是已完成
|
||||||
|
boolean flag = list.stream().allMatch(process -> process.getStatus().equals("2"));
|
||||||
|
if (flag) {
|
||||||
|
newProcess = list.stream().max(Comparator.comparing(Process::getSubject)).orElse(null);
|
||||||
|
}else {
|
||||||
|
newProcess = list.stream().min(Comparator.comparing(Process::getSubject)).orElse(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
item.setProcess(newProcess);
|
||||||
});
|
});
|
||||||
return pageResult;
|
return pageResult;
|
||||||
}
|
}
|
||||||
|
@ -29,4 +29,10 @@ public class DlDriveSchoolStudentVO extends DlDriveSchoolStudent {
|
|||||||
private String startTime;
|
private String startTime;
|
||||||
/**查询时间范围--结束*/
|
/**查询时间范围--结束*/
|
||||||
private String endTime;
|
private String endTime;
|
||||||
|
/**订单表中的毕业时间*/
|
||||||
|
private String orderGradTime;
|
||||||
|
/**课程名称*/
|
||||||
|
private String courseName;
|
||||||
|
/**订单ID*/
|
||||||
|
private String orderId;
|
||||||
}
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
package cn.iocoder.yudao.module.base.vo;
|
||||||
|
|
||||||
|
import cn.iocoder.yudao.module.base.entity.DriveSchoolCourseDeduct;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class DriveSchoolCourseDeductVO extends DriveSchoolCourseDeduct {
|
||||||
|
/**课程名称*/
|
||||||
|
private String courseName;
|
||||||
|
}
|
@ -2,6 +2,7 @@ package cn.iocoder.yudao.module.course.service.impl;
|
|||||||
|
|
||||||
import cn.hutool.core.bean.BeanUtil;
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
import cn.hutool.core.collection.CollUtil;
|
import cn.hutool.core.collection.CollUtil;
|
||||||
|
import cn.hutool.core.util.ObjectUtil;
|
||||||
import cn.hutool.core.util.StrUtil;
|
import cn.hutool.core.util.StrUtil;
|
||||||
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
|
||||||
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
|
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
|
||||||
@ -327,12 +328,49 @@ public class ProcessServiceImpl extends ServiceImpl<ProcessMapper, Process> impl
|
|||||||
.eq(SchoolCourseOrder::getId, request.getOrderId())
|
.eq(SchoolCourseOrder::getId, request.getOrderId())
|
||||||
.set(SchoolCourseOrder::getIfAssignmentCoach, SchoolBaseConstants.SCHOOL_COURSE_ORDER_IS_ASSIGN_COACH));
|
.set(SchoolCourseOrder::getIfAssignmentCoach, SchoolBaseConstants.SCHOOL_COURSE_ORDER_IS_ASSIGN_COACH));
|
||||||
|
|
||||||
|
// 查询进度
|
||||||
|
List<Process> processList = list(Wrappers.lambdaQuery(Process.class)
|
||||||
|
.eq(Process::getCourseId, courseId)
|
||||||
|
.eq(Process::getUserId, userId));
|
||||||
|
|
||||||
|
Process process = processList.stream()
|
||||||
|
.filter(p -> "1".equals(p.getStatus()))
|
||||||
|
.findFirst()
|
||||||
|
.orElse(null);
|
||||||
|
|
||||||
|
if (process == null) {
|
||||||
|
// 没有进行中的
|
||||||
|
Process maxCompleted = processList.stream()
|
||||||
|
.filter(p -> "2".equals(p.getStatus()))
|
||||||
|
.max(Comparator.comparing(Process::getSubject))
|
||||||
|
.orElse(null);
|
||||||
|
|
||||||
|
if (maxCompleted != null) {
|
||||||
|
// 尝试找 subject == maxCompleted + 1 的
|
||||||
|
Process next = processList.stream()
|
||||||
|
.filter(p -> p.getSubject().equals(maxCompleted.getSubject() + 1))
|
||||||
|
.findFirst()
|
||||||
|
.orElse(null);
|
||||||
|
|
||||||
|
process = next != null ? next : maxCompleted;
|
||||||
|
} else {
|
||||||
|
// 没有已完成的,找 subject 最小的
|
||||||
|
process = processList.stream()
|
||||||
|
.min(Comparator.comparing(Process::getSubject))
|
||||||
|
.orElse(null);
|
||||||
|
}
|
||||||
|
process.setStatus("1");
|
||||||
|
//更新
|
||||||
|
updateById(process);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// 发送通知内容
|
// 发送通知内容
|
||||||
String message = String.format(SchoolBaseConstants.SCHOOL_NOTIFY_MESSAGE_TEMPLATE_ASSIGN_COACH,
|
String message = String.format(SchoolBaseConstants.SCHOOL_NOTIFY_MESSAGE_TEMPLATE_ASSIGN_COACH,
|
||||||
processes.get(0).getCoachName(),
|
request.getProcessList().get(0).getCoachName(),
|
||||||
processes.get(1).getCoachName(),
|
request.getProcessList().get(1).getCoachName(),
|
||||||
processes.get(2).getCoachName(),
|
request.getProcessList().get(2).getCoachName(),
|
||||||
processes.get(3).getCoachName());
|
request.getProcessList().get(3).getCoachName());
|
||||||
|
|
||||||
// 发送消息给学员
|
// 发送消息给学员
|
||||||
schoolNotifyMessageSendService.sendMessage(userId, message, SchoolBaseConstants.SCHOOL_NOTIFY_MESSAGE_TYPE_MEMBER, null);
|
schoolNotifyMessageSendService.sendMessage(userId, message, SchoolBaseConstants.SCHOOL_NOTIFY_MESSAGE_TYPE_MEMBER, null);
|
||||||
|
@ -105,12 +105,15 @@
|
|||||||
FROM
|
FROM
|
||||||
(
|
(
|
||||||
SELECT
|
SELECT
|
||||||
dss.*
|
dss.*,dsco.id AS orderId,dsco.course_name,dsp.coach_id,dsp.course_id
|
||||||
FROM
|
FROM
|
||||||
drive_school_process dsp
|
drive_school_process dsp
|
||||||
LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id
|
LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id
|
||||||
|
LEFT JOIN drive_school_course_order dsco ON dsp.user_id = dsco.user_id AND dsp.course_id = dsco.course_id
|
||||||
WHERE
|
WHERE
|
||||||
dsp.deleted = 0
|
dsp.deleted = 0
|
||||||
|
AND dsco.if_end = 0
|
||||||
|
AND dsco.deleted = 0
|
||||||
AND dsp.coach_id = #{entity.coachId}
|
AND dsp.coach_id = #{entity.coachId}
|
||||||
<if test="entity.name != null and entity.name!=''">
|
<if test="entity.name != null and entity.name!=''">
|
||||||
AND dss.`name` LIKE CONCAT('%',#{entity.name},'%')
|
AND dss.`name` LIKE CONCAT('%',#{entity.name},'%')
|
||||||
@ -126,7 +129,7 @@
|
|||||||
dss.create_time DESC
|
dss.create_time DESC
|
||||||
) temp
|
) temp
|
||||||
GROUP BY
|
GROUP BY
|
||||||
temp.user_id
|
temp.orderId
|
||||||
</select>
|
</select>
|
||||||
<select id="selectStudentList" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
<select id="selectStudentList" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
||||||
SELECT
|
SELECT
|
||||||
@ -150,13 +153,15 @@
|
|||||||
</select>
|
</select>
|
||||||
<select id="selectStudentListCoach" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
<select id="selectStudentListCoach" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
||||||
SELECT
|
SELECT
|
||||||
dss.*
|
dss.*,dsco.grad_time AS orderGradTime,dsco.id AS orderId
|
||||||
FROM
|
FROM
|
||||||
drive_school_process dsp
|
drive_school_process dsp
|
||||||
LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id
|
LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id
|
||||||
AND dss.deleted = 0
|
LEFT JOIN drive_school_course_order dsco ON dsp.user_id = dsco.user_id AND dsp.course_id = dsco.course_id
|
||||||
WHERE
|
WHERE
|
||||||
dsp.deleted = 0
|
dsp.deleted = 0
|
||||||
|
AND dsco.if_end = 0
|
||||||
|
AND dsco.deleted = 0
|
||||||
AND dss.id IS NOT NULL
|
AND dss.id IS NOT NULL
|
||||||
<if test="coachId != null and coachId != ''">
|
<if test="coachId != null and coachId != ''">
|
||||||
AND dsp.coach_id = #{coachId}
|
AND dsp.coach_id = #{coachId}
|
||||||
@ -168,7 +173,27 @@
|
|||||||
AND dss.create_time <= #{endTime}
|
AND dss.create_time <= #{endTime}
|
||||||
</if>
|
</if>
|
||||||
GROUP BY
|
GROUP BY
|
||||||
dss.id
|
dsco.id
|
||||||
|
<!-- 旧的sql-->
|
||||||
|
<!-- SELECT-->
|
||||||
|
<!-- dss.*-->
|
||||||
|
<!-- FROM-->
|
||||||
|
<!-- drive_school_process dsp-->
|
||||||
|
<!-- LEFT JOIN drive_school_student dss ON dsp.user_id = dss.user_id-->
|
||||||
|
<!-- WHERE-->
|
||||||
|
<!-- dsp.deleted = 0-->
|
||||||
|
<!-- AND dss.id IS NOT NULL-->
|
||||||
|
<!-- <if test="coachId != null and coachId != ''">-->
|
||||||
|
<!-- AND dsp.coach_id = #{coachId}-->
|
||||||
|
<!-- </if>-->
|
||||||
|
<!-- <if test="startTime!=null and startTime!=''">-->
|
||||||
|
<!-- AND dss.create_time >= #{startTime}-->
|
||||||
|
<!-- </if>-->
|
||||||
|
<!-- <if test="endTime!=null and endTime!=''">-->
|
||||||
|
<!-- AND dss.create_time <= #{endTime}-->
|
||||||
|
<!-- </if>-->
|
||||||
|
<!-- GROUP BY-->
|
||||||
|
<!-- dsp.id-->
|
||||||
</select>
|
</select>
|
||||||
<select id="selectTrainStudent" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
<select id="selectTrainStudent" resultType="cn.iocoder.yudao.module.base.vo.DlDriveSchoolStudentVO">
|
||||||
SELECT
|
SELECT
|
||||||
|
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper
|
||||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="cn.iocoder.yudao.module.base.mapper.DriveSchoolCourseDeductMapper">
|
||||||
|
|
||||||
|
<select id="queryPage" resultType="cn.iocoder.yudao.module.base.vo.DriveSchoolCourseDeductVO">
|
||||||
|
SELECT main.*, dsc.name AS courseName
|
||||||
|
FROM drive_school_course_deduct main
|
||||||
|
LEFT JOIN drive_school_course dsc ON main.course_id = dsc.id
|
||||||
|
</select>
|
||||||
|
</mapper>
|
Loading…
Reference in New Issue
Block a user