Commit 2c42e64f4f72d2b651290da09436f9650b69d00d
1 parent
037d605e
Exists in
master
排课 一个老师对应多个课程 优化
Showing
10 changed files
with
307 additions
and
301 deletions
Show diff stats
src/main/java/com/jevon/controller/LearnStatController.java
... | ... | @@ -579,6 +579,20 @@ public class LearnStatController { |
579 | 579 | return repVO; |
580 | 580 | } |
581 | 581 | |
582 | + @ApiOperation("getForm2_2_5") | |
583 | + @RequestMapping(value = "getForm2_2_5", method = RequestMethod.POST) | |
584 | + public Map<String,Double> getForm2_2_5(@RequestBody GetLearnReqVo getLearnReqVo){ | |
585 | + Analyse analyse = analyseService.selectById(getLearnReqVo.getAnalyseId()); | |
586 | + //分数段 | |
587 | + Double maxScore = analyse.getMaxScore(); | |
588 | + Map<String,Double> segmentMap = new HashMap<>(); | |
589 | + segmentMap.put("A",maxScore*0.85); | |
590 | + segmentMap.put("B",maxScore*0.7); | |
591 | + segmentMap.put("C",maxScore*0.6); | |
592 | + segmentMap.put("D",maxScore*0.6); | |
593 | + return segmentMap ; | |
594 | + } | |
595 | + | |
582 | 596 | @ApiOperation("getForm3_1") |
583 | 597 | @RequestMapping(value = "getForm3_1", method = RequestMethod.POST) |
584 | 598 | public Form6RepVO getForm3_1(@RequestBody GetLearnReqVo getLearnReqVo){ | ... | ... |
src/main/java/com/jevon/controller/ScheduleController.java
... | ... | @@ -236,13 +236,8 @@ public class ScheduleController { |
236 | 236 | for(String msg : parallelClassReqVo.getIntervalList()){ |
237 | 237 | String[] arrayMsg = msg.split("-"); |
238 | 238 | ClassCourse classCourse = new ClassCourse(); |
239 | - if(Integer.valueOf(arrayMsg[0]) > 5){ | |
240 | - classCourse.setSingleOrDouble(2); | |
241 | - classCourse.setWeek(Integer.valueOf(arrayMsg[0])-5); | |
242 | - }else { | |
243 | - classCourse.setSingleOrDouble(1); | |
244 | - classCourse.setWeek(Integer.valueOf(arrayMsg[0])); | |
245 | - } | |
239 | + classCourse.setSingleOrDouble(1); | |
240 | + classCourse.setWeek(Integer.valueOf(arrayMsg[0])); | |
246 | 241 | classCourse.setCourseNumber(Integer.valueOf(arrayMsg[1])); |
247 | 242 | limitList.add(classCourse); |
248 | 243 | } |
... | ... | @@ -291,10 +286,11 @@ public class ScheduleController { |
291 | 286 | insertTeacherCourse(isDouble, teacherCourse); |
292 | 287 | } |
293 | 288 | TeacherClass searchTeacher = new TeacherClass(); |
294 | - searchTeacher.setTeacherName(temp.getTeacherName()); | |
295 | 289 | searchTeacher.setSchoolId(temp.getSchoolId()); |
296 | - searchTeacher.setClassId(temp.getClassId()); | |
297 | 290 | searchTeacher.setTeam(temp.getTeam()); |
291 | + searchTeacher.setClassId(temp.getClassId()); | |
292 | + searchTeacher.setTeacherName(temp.getTeacherName()); | |
293 | + searchTeacher.setCourseName(temp.getCourseName()); | |
298 | 294 | TeacherClass teacherClass = teacherClassService.selectByTeacher(searchTeacher); |
299 | 295 | if(teacherClass.getStatus() == 1){ |
300 | 296 | //已经排课不再排课 |
... | ... | @@ -302,47 +298,32 @@ public class ScheduleController { |
302 | 298 | ClassCourse classCourse = new ClassCourse(); |
303 | 299 | classCourse.setClassId(temp.getClassId()); |
304 | 300 | classCourse.setTeam(schedule.getTeam()); |
305 | - if(isDouble){ | |
306 | -// //双周排课 先排第一周 | |
307 | -// int times = teacherClass.getTimes(); | |
308 | -// int joinTimes = teacherClass.getJoinTimes(); | |
309 | -// classCourse.setSingleOrDouble(1); | |
310 | -// teacherClass.setJoinTimes(times/2); | |
311 | -// teacherClass.setJoinTimes(joinTimes/2); | |
312 | -// List<ClassCourse> classCourses = classCourseService.selectByClassIdAndSingleOrDouble(classCourse); | |
313 | -// initWeekCourse(joinList,teacherClass,teacherCourse,classCourses,limitList,0); | |
314 | -// //第二周 | |
315 | -// classCourse.setSingleOrDouble(1); | |
316 | -// teacherClass.setJoinTimes(times/2+1); | |
317 | -// teacherClass.setJoinTimes(joinTimes/2+1); | |
318 | -// classCourses = classCourseService.selectByClassIdAndSingleOrDouble(classCourse); | |
319 | -// initWeekCourse(joinList,teacherClass,teacherCourse,classCourses,limitList,0); | |
320 | - }else { | |
321 | - classCourse.setSingleOrDouble(1); | |
322 | - List<ClassCourse> classCourses = classCourseService.selectByClassIdAndSingleOrDouble(classCourse); | |
323 | - initWeekCourse(joinList,teacherClass,teacherCourse,classCourses,limitList,0); | |
324 | - //排课结束,更新 | |
325 | - //如果是合班的话,需要更新多个teacherClass | |
326 | - teacherClassService.updateSchedule(teacherClass.gettClassId()); | |
327 | - JoinClass joinClass = new JoinClass(); | |
328 | - joinClass.setSchoolId(schedule.getSchoolId()); | |
329 | - joinClass.setTeam(schedule.getTeam()); | |
330 | - joinClass.setCourseId(courseService.selectBySchoolIdAndCourseName(schedule.getSchoolId(),teacherClass.getCourseName()).getCourseId()); | |
331 | - joinClass.setClassId(classCourse.getClassId()); | |
332 | - List<JoinClass> joinClasses = joinClassService.selectByCourse(joinClass); | |
333 | - if(joinClasses != null && joinClasses.size() > 0){ | |
334 | - List<JoinClass> resultList = joinClassService.selectByCourseGroup(joinClasses.get(0).getCourseGroup()); | |
335 | - for(JoinClass joinClass1 :resultList){ | |
336 | - TeacherClass searchTeacherClass = new TeacherClass(); | |
337 | - searchTeacherClass.setSchoolId(schedule.getSchoolId()); | |
338 | - searchTeacherClass.setTeam(schedule.getTeam()); | |
339 | - searchTeacherClass.setCourseName(teacherClass.getCourseName()); | |
340 | - searchTeacherClass.setClassId(joinClass1.getClassId()); | |
341 | - TeacherClass resultTeacherClass = teacherClassService.selectByCourseAndClass(searchTeacherClass); | |
342 | - teacherClassService.updateSchedule(resultTeacherClass.gettClassId()); | |
343 | - } | |
301 | + classCourse.setSchoolId(schedule.getSchoolId()); | |
302 | + classCourse.setSingleOrDouble(1); | |
303 | + List<ClassCourse> classCourses = classCourseService.selectByClassIdAndSingleOrDouble(classCourse); | |
304 | + initWeekCourse(parallelClassReqVo.getCourseType(),joinList,teacherClass,classCourses,limitList,0); | |
305 | + //排课结束,更新 | |
306 | + //如果是合班的话,需要更新多个teacherClass | |
307 | + teacherClassService.updateSchedule(teacherClass.gettClassId()); | |
308 | + JoinClass joinClass = new JoinClass(); | |
309 | + joinClass.setSchoolId(schedule.getSchoolId()); | |
310 | + joinClass.setTeam(schedule.getTeam()); | |
311 | + joinClass.setCourseId(courseService.selectBySchoolIdAndCourseName(schedule.getSchoolId(),teacherClass.getCourseName()).getCourseId()); | |
312 | + joinClass.setClassId(classCourse.getClassId()); | |
313 | + List<JoinClass> joinClasses = joinClassService.selectByCourse(joinClass); | |
314 | + if(joinClasses != null && joinClasses.size() > 0){ | |
315 | + List<JoinClass> resultList = joinClassService.selectByCourseGroup(joinClasses.get(0).getCourseGroup()); | |
316 | + for(JoinClass joinClass1 :resultList){ | |
317 | + TeacherClass searchTeacherClass = new TeacherClass(); | |
318 | + searchTeacherClass.setSchoolId(schedule.getSchoolId()); | |
319 | + searchTeacherClass.setTeam(schedule.getTeam()); | |
320 | + searchTeacherClass.setCourseName(teacherClass.getCourseName()); | |
321 | + searchTeacherClass.setClassId(joinClass1.getClassId()); | |
322 | + TeacherClass resultTeacherClass = teacherClassService.selectByCourseAndClass(searchTeacherClass); | |
323 | + teacherClassService.updateSchedule(resultTeacherClass.gettClassId()); | |
344 | 324 | } |
345 | 325 | } |
326 | + | |
346 | 327 | } |
347 | 328 | } |
348 | 329 | return baseVo; |
... | ... | @@ -422,7 +403,16 @@ public class ScheduleController { |
422 | 403 | return classCourses; |
423 | 404 | } |
424 | 405 | |
425 | - private void initWeekCourse(List<Integer> joinList ,TeacherClass teacherClass , TeacherCourse teacherCourse , | |
406 | + /** | |
407 | + * | |
408 | + * @param courseType 所排课的课程类型 // 1 主课 2 副课 3 公共课 | |
409 | + * @param joinList 联课优先级 | |
410 | + * @param teacherClass 老师授课信息 | |
411 | + * @param list 班级课程 | |
412 | + * @param limitList 单课优先级 | |
413 | + * @param functionTimes 循环次数 | |
414 | + */ | |
415 | + private void initWeekCourse(int courseType ,List<Integer> joinList ,TeacherClass teacherClass , | |
426 | 416 | List<ClassCourse> list , List<ClassCourse> limitList ,int functionTimes){ |
427 | 417 | List<Integer> sort = new ArrayList<>(); |
428 | 418 | String team = teacherClass.getTeam(); |
... | ... | @@ -448,19 +438,19 @@ public class ScheduleController { |
448 | 438 | } |
449 | 439 | ClassCourse classCourseNext =getClassCourse(list, week, courseNumber+1); |
450 | 440 | if (StringUtils.isBlank(classCourse.getCourseName()) && StringUtils.isBlank(classCourseNext.getCourseName())) { |
451 | - Course course = courseService.selectBySchoolIdAndCourseName(teacherClass.getSchoolId(),teacherCourse.getCourseName()); | |
441 | + Course course = courseService.selectBySchoolIdAndCourseName(teacherClass.getSchoolId(),teacherClass.getCourseName()); | |
452 | 442 | classCourse.setCourseOpenId(course.getCourseId()); |
453 | 443 | classCourse.setCourseName(teacherClass.getCourseName()); |
454 | 444 | classCourseNext.setCourseOpenId(course.getCourseId()); |
455 | 445 | classCourseNext.setCourseName(teacherClass.getCourseName()); |
456 | 446 | TeacherCourse searchTeacherCourse = new TeacherCourse(); |
457 | 447 | searchTeacherCourse.setTeam(team); |
458 | - searchTeacherCourse.setSchoolId(teacherCourse.getSchoolId()); | |
459 | - searchTeacherCourse.setGrade(teacherCourse.getGrade()); | |
460 | - searchTeacherCourse.setTeacherName(teacherCourse.getTeacherName()); | |
448 | + searchTeacherCourse.setSchoolId(teacherClass.getSchoolId()); | |
449 | + searchTeacherCourse.setGrade(teacherClass.getGrade()); | |
450 | + searchTeacherCourse.setTeacherName(teacherClass.getTeacherName()); | |
461 | 451 | searchTeacherCourse.setSingleOrDouble(singleOrDouble); |
462 | 452 | searchTeacherCourse.setWeek(week); |
463 | - searchTeacherCourse.setCourseName(teacherCourse.getCourseName()); | |
453 | + searchTeacherCourse.setCourseName(teacherClass.getCourseName()); | |
464 | 454 | //查询当天老师的课是否已经大于等于2 防止老师一天课程太多 |
465 | 455 | int dayCourse = teacherCourseService.selectTeacherDayCourseNumber(searchTeacherCourse); |
466 | 456 | if(dayCourse >= 2){ |
... | ... | @@ -473,9 +463,9 @@ public class ScheduleController { |
473 | 463 | if (StringUtils.isBlank(teacherFirst.getCourseName()) && StringUtils.isBlank(teacherSecond.getCourseName())) { |
474 | 464 | classCourseService.updateByPrimaryKey(classCourse); |
475 | 465 | classCourseService.updateByPrimaryKey(classCourseNext); |
476 | - teacherFirst.setCourseName(teacherCourse.getCourseName()); | |
466 | + teacherFirst.setCourseName(teacherClass.getCourseName()); | |
477 | 467 | teacherFirst.setClassId(classCourse.getClassId()+""); |
478 | - teacherSecond.setCourseName(teacherCourse.getCourseName()); | |
468 | + teacherSecond.setCourseName(teacherClass.getCourseName()); | |
479 | 469 | teacherSecond.setClassId(classCourse.getClassId()+""); |
480 | 470 | teacherCourseService.updateTeacherCourse(teacherFirst); |
481 | 471 | teacherCourseService.updateTeacherCourse(teacherSecond); |
... | ... | @@ -515,118 +505,170 @@ public class ScheduleController { |
515 | 505 | if(flag){ |
516 | 506 | if(StringUtils.isBlank(classCourse.getCourseName())){ |
517 | 507 | Course course = courseService.selectBySchoolIdAndCourseName(teacherClass.getSchoolId(),teacherClass.getCourseName()); |
518 | - classCourse.setCourseOpenId(course.getCourseId()); | |
519 | - classCourse.setCourseName(teacherClass.getCourseName()); | |
520 | - //判断当天是否已经排该课程 | |
521 | - if(classCourseService.selectCourseByClassIdAndWeek(classCourse) > 1){ | |
522 | - break; | |
508 | + //约束条件判断 | |
509 | + TeacherCourse result = checkConstraint(courseType,classCourse,teacherClass,course,singleOrDouble,week,courseNumber); | |
510 | + if(result == null){ | |
511 | + break; | |
523 | 512 | } |
524 | - TeacherCourse searchTeacherCourse = new TeacherCourse(); | |
525 | - searchTeacherCourse.setTeam(team); | |
526 | - searchTeacherCourse.setSchoolId(teacherCourse.getSchoolId()); | |
527 | - searchTeacherCourse.setGrade(teacherCourse.getGrade()); | |
528 | - searchTeacherCourse.setTeacherName(teacherCourse.getTeacherName()); | |
529 | - searchTeacherCourse.setSingleOrDouble(singleOrDouble); | |
530 | - searchTeacherCourse.setWeek(week); | |
531 | - searchTeacherCourse.setCourseNumber(courseNumber); | |
532 | - searchTeacherCourse.setCourseName(teacherClass.getCourseName()); | |
533 | - TeacherCourse result = teacherCourseService.selectTeacherCourse(searchTeacherCourse); | |
534 | - //老师当天课程不能多于2 | |
535 | - if(teacherCourseService.selectTeacherDayCourseNumber(searchTeacherCourse) >= 2){ | |
513 | + //设置课程 | |
514 | + if(setCourse(classCourse,teacherClass,result,course)){ | |
515 | + times++; | |
516 | + before = courseNumber; | |
536 | 517 | break; |
537 | - } | |
538 | - //合课 多做一层判断 另一个班级这节课也为空 | |
539 | - JoinClass joinClass = new JoinClass(); | |
540 | - joinClass.setSchoolId(classCourse.getSchoolId()); | |
541 | - joinClass.setTeam(classCourse.getTeam()); | |
542 | - joinClass.setCourseId(classCourse.getCourseOpenId()); | |
543 | - joinClass.setClassId(classCourse.getClassId()); | |
544 | - List<JoinClass> joinClasses = joinClassService.selectByCourse(joinClass); | |
545 | - if(joinClasses != null && joinClasses.size() > 0){ | |
546 | - //说明是合班的课程 | |
547 | - boolean isClash = false ; | |
548 | - List<ClassCourse> joinClassList = new ArrayList<>(); | |
549 | - List<JoinClass> resultList = joinClassService.selectByCourseGroup(joinClasses.get(0).getCourseGroup()); | |
550 | - for(JoinClass temp : resultList){ | |
551 | - ClassCourse joinClassCourse = new ClassCourse(); | |
552 | - joinClassCourse.setTeam(classCourse.getTeam()); | |
553 | - joinClassCourse.setClassId(temp.getClassId()); | |
554 | - joinClassCourse.setWeek(classCourse.getWeek()); | |
555 | - joinClassCourse.setCourseNumber(classCourse.getCourseNumber()); | |
556 | - joinClassCourse.setSingleOrDouble(classCourse.getSingleOrDouble()); | |
557 | - ClassCourse joinResultClassCourse = classCourseService.selectClassCourse(joinClassCourse); | |
558 | - joinClassList.add(joinResultClassCourse); | |
559 | - if(StringUtils.isNotBlank(joinResultClassCourse.getCourseName())){ | |
560 | - isClash = true ; | |
561 | - break; | |
562 | - } | |
563 | - } | |
564 | - if(isClash){ | |
565 | - //合班的班级有 该节次的课 已经有老师上了 | |
566 | - continue; | |
567 | - }else { | |
568 | - String classIdString = ""; | |
569 | - for(ClassCourse temp : joinClassList){ | |
570 | - classIdString = course.getCourseId() + "," ; | |
571 | - temp.setCourseOpenId(course.getCourseId()); | |
572 | - temp.setCourseName(teacherClass.getCourseName()); | |
573 | - classCourseService.updateByPrimaryKey(temp); | |
574 | - } | |
575 | - result.setGrade(classCourse.getGrade()); | |
576 | - result.setClassId(classIdString); | |
577 | - result.setCourseName(classCourse.getCourseName()); | |
578 | - teacherCourseService.updateTeacherCourse(result); | |
579 | - times++; | |
580 | - before = courseNumber; | |
581 | - break; | |
582 | - } | |
583 | 518 | }else { |
584 | - //普通课程 | |
585 | - if(StringUtils.isBlank(result.getCourseName())){ | |
586 | - classCourseService.updateByPrimaryKey(classCourse); | |
587 | - result.setGrade(classCourse.getGrade()); | |
588 | - result.setClassId(classCourse.getClassId()+""); | |
589 | - result.setCourseName(classCourse.getCourseName()); | |
590 | - teacherCourseService.updateTeacherCourse(result); | |
591 | - times++; | |
592 | - before = courseNumber; | |
593 | - break; | |
594 | - }else { | |
595 | - continue; | |
596 | - } | |
519 | + continue; | |
597 | 520 | } |
598 | 521 | } |
599 | 522 | } |
600 | 523 | } |
601 | 524 | } |
602 | - if(functionTimes > 1){ | |
525 | + if(functionTimes > 2){ | |
603 | 526 | //递归次数限制,防止无限循环,内存溢出,手动优化课程 |
604 | - optimizeCourse(teacherClass); | |
527 | + optimizeCourse(teacherClass,courseType); | |
605 | 528 | }else{ |
606 | 529 | if(times < teacherClass.getTimes()){ |
607 | 530 | //优先时段中课程数 不够 |
608 | 531 | teacherClass.setTimes(teacherClass.getTimes()-times); |
609 | 532 | teacherClass.setJoinTimes(teacherClass.getJoinTimes()-joinTimes); |
610 | - //放大范围 | |
611 | - limitList = new ArrayList<>(); | |
533 | + //放大优先范围,上下一节,并去掉原来的优先范围 | |
534 | + List<ClassCourse> newLimitList = new ArrayList<>(); | |
612 | 535 | int maxCourseNumber =classCourseService.selectMaxCourseNumber(teacherClass.getSchoolId(),team); |
613 | - for(int i = 1 ; i<= 5 ; i++){ | |
614 | - for(int j = 1 ; j <=maxCourseNumber ; j++) { | |
536 | + for(ClassCourse classCourse : limitList){ | |
537 | + if(classCourse.getCourseNumber() == 1){ | |
615 | 538 | ClassCourse temp = new ClassCourse(); |
616 | - temp.setWeek(i); | |
617 | - temp.setCourseNumber(j); | |
618 | - limitList.add(temp); | |
539 | + temp.setWeek(classCourse.getWeek()); | |
540 | + temp.setCourseNumber(2); | |
541 | + newLimitList.add(temp); | |
542 | + }else if(classCourse.getCourseNumber() == maxCourseNumber){ | |
543 | + ClassCourse temp = new ClassCourse(); | |
544 | + temp.setWeek(classCourse.getWeek()); | |
545 | + temp.setCourseNumber(maxCourseNumber-1); | |
546 | + newLimitList.add(temp); | |
547 | + }else{ | |
548 | + ClassCourse temp = new ClassCourse(); | |
549 | + temp.setWeek(classCourse.getWeek()); | |
550 | + temp.setCourseNumber(classCourse.getCourseNumber()-1); | |
551 | + newLimitList.add(temp); | |
552 | + ClassCourse temp2 = new ClassCourse(); | |
553 | + temp2.setWeek(classCourse.getWeek()); | |
554 | + temp2.setCourseNumber(classCourse.getCourseNumber()+1); | |
555 | + newLimitList.add(temp2); | |
556 | + } | |
557 | + } | |
558 | + List<ClassCourse> result = new ArrayList<>(); | |
559 | + for (int i = 0; i < newLimitList.size() ; i++) { | |
560 | + boolean isExist = false ; | |
561 | + for(ClassCourse classCourse : limitList){ | |
562 | + if(newLimitList.get(i).getWeek() == classCourse.getWeek() && | |
563 | + newLimitList.get(i).getCourseNumber() == classCourse.getCourseNumber()){ | |
564 | + isExist = true ; | |
565 | + } | |
566 | + } | |
567 | + if(!isExist){ | |
568 | + result.add(newLimitList.get(i)); | |
619 | 569 | } |
620 | 570 | } |
621 | 571 | functionTimes ++ ; |
622 | - initWeekCourse(joinList,teacherClass,teacherCourse,list,limitList,functionTimes); | |
572 | + initWeekCourse(courseType,joinList,teacherClass,list,result,functionTimes); | |
573 | + } | |
574 | + } | |
575 | + } | |
576 | + | |
577 | + //设置课程 | |
578 | + private boolean setCourse(ClassCourse classCourse ,TeacherClass teacherClass , TeacherCourse result , Course course){ | |
579 | + //合课 多做一层判断 另一个班级这节课也为空 | |
580 | + JoinClass joinClass = new JoinClass(); | |
581 | + joinClass.setSchoolId(classCourse.getSchoolId()); | |
582 | + joinClass.setTeam(classCourse.getTeam()); | |
583 | + joinClass.setCourseId(classCourse.getCourseOpenId()); | |
584 | + joinClass.setClassId(classCourse.getClassId()); | |
585 | + List<JoinClass> joinClasses = joinClassService.selectByCourse(joinClass); | |
586 | + if(joinClasses != null && joinClasses.size() > 0){ | |
587 | + //说明是合班的课程 | |
588 | + boolean isClash = false ; | |
589 | + List<ClassCourse> joinClassList = new ArrayList<>(); | |
590 | + List<JoinClass> resultList = joinClassService.selectByCourseGroup(joinClasses.get(0).getCourseGroup()); | |
591 | + for(JoinClass temp : resultList){ | |
592 | + ClassCourse joinClassCourse = new ClassCourse(); | |
593 | + joinClassCourse.setTeam(classCourse.getTeam()); | |
594 | + joinClassCourse.setClassId(temp.getClassId()); | |
595 | + joinClassCourse.setWeek(classCourse.getWeek()); | |
596 | + joinClassCourse.setCourseNumber(classCourse.getCourseNumber()); | |
597 | + joinClassCourse.setSingleOrDouble(classCourse.getSingleOrDouble()); | |
598 | + ClassCourse joinResultClassCourse = classCourseService.selectClassCourse(joinClassCourse); | |
599 | + joinClassList.add(joinResultClassCourse); | |
600 | + if(StringUtils.isNotBlank(joinResultClassCourse.getCourseName())){ | |
601 | + isClash = true ; | |
602 | + break; | |
603 | + } | |
604 | + } | |
605 | + if(isClash){ | |
606 | + //合班的班级有 该节次的课 已经有老师上了 | |
607 | + return false; | |
608 | + }else { | |
609 | + String classIdString = ""; | |
610 | + for(ClassCourse temp : joinClassList){ | |
611 | + classIdString = course.getCourseId() + "," ; | |
612 | + temp.setCourseOpenId(course.getCourseId()); | |
613 | + temp.setCourseName(teacherClass.getCourseName()); | |
614 | + classCourseService.updateByPrimaryKey(temp); | |
615 | + } | |
616 | + result.setGrade(classCourse.getGrade()); | |
617 | + result.setClassId(classIdString); | |
618 | + result.setCourseName(classCourse.getCourseName()); | |
619 | + teacherCourseService.updateTeacherCourse(result); | |
620 | + return true; | |
623 | 621 | } |
622 | + }else { | |
623 | + //普通课程 | |
624 | + if(StringUtils.isBlank(result.getCourseName())){ | |
625 | + classCourseService.updateByPrimaryKey(classCourse); | |
626 | + result.setGrade(classCourse.getGrade()); | |
627 | + result.setClassId(classCourse.getClassId()+""); | |
628 | + result.setCourseName(classCourse.getCourseName()); | |
629 | + teacherCourseService.updateTeacherCourse(result); | |
630 | + return true; | |
631 | + }else { | |
632 | + return false ; | |
633 | + } | |
634 | + } | |
635 | + } | |
636 | + | |
637 | + //判断班级与老师的约束条件 | |
638 | + private TeacherCourse checkConstraint(int courseType , ClassCourse classCourse , TeacherClass teacherClass , | |
639 | + Course course , int singleOrDouble , int week , int courseNumber ){ | |
640 | + classCourse.setCourseOpenId(course.getCourseId()); | |
641 | + classCourse.setCourseName(teacherClass.getCourseName()); | |
642 | + //判断当天是否已经排该课程 主课一天2节,其他课一天1节 | |
643 | + if(courseType == 1 && classCourseService.selectCourseByClassIdAndWeek(classCourse) >= 2){ | |
644 | + return null ; | |
645 | + } | |
646 | + if(courseType != 1 && classCourseService.selectCourseByClassIdAndWeek(classCourse) >= 1){ | |
647 | + return null ; | |
624 | 648 | } |
649 | + TeacherCourse searchTeacherCourse = new TeacherCourse(); | |
650 | + searchTeacherCourse.setTeam(teacherClass.getTeam()); | |
651 | + searchTeacherCourse.setSchoolId(teacherClass.getSchoolId()); | |
652 | + searchTeacherCourse.setGrade(teacherClass.getGrade()); | |
653 | + searchTeacherCourse.setTeacherName(teacherClass.getTeacherName()); | |
654 | + searchTeacherCourse.setSingleOrDouble(singleOrDouble); | |
655 | + searchTeacherCourse.setWeek(week); | |
656 | + searchTeacherCourse.setCourseNumber(courseNumber); | |
657 | + searchTeacherCourse.setCourseName(teacherClass.getCourseName()); | |
658 | + TeacherCourse result = teacherCourseService.selectTeacherCourse(searchTeacherCourse); | |
659 | + //老师当天课程不能多于 该老师平均课程 | |
660 | + if(teacherCourseService.selectTeacherDayCourseNumber(searchTeacherCourse) | |
661 | + >= teacherClassService.selectTeacherDayClass(teacherClass.getSchoolId(),teacherClass.getTeam(),teacherClass.getTeacherName())){ | |
662 | + return null ; | |
663 | + } | |
664 | + return result ; | |
625 | 665 | } |
626 | 666 | |
667 | + | |
627 | 668 | //课程冲突 ,调优 |
628 | - private void optimizeCourse(TeacherClass teacherClass){ | |
669 | + private void optimizeCourse(TeacherClass teacherClass,int courseType){ | |
629 | 670 | int times = teacherClass.getTimes(); |
671 | + int maxCourseNumber = classCourseService.selectMaxCourseNumber(teacherClass.getSchoolId(),teacherClass.getTeam()) ; | |
630 | 672 | while (times > 0){ |
631 | 673 | boolean flag = false ; |
632 | 674 | List<ClassCourse> noClassList = classCourseService.selectNoCourse(teacherClass.getClassId(),teacherClass.getTeam()); |
... | ... | @@ -646,7 +688,7 @@ public class ScheduleController { |
646 | 688 | } |
647 | 689 | for(int j = -1 ; j<=1 ; j++){ |
648 | 690 | int courseNumberChange = classCourse.getCourseNumber() + j ; |
649 | - if(courseNumberChange > classCourseService.selectMaxCourseNumber(teacherClass.getSchoolId(),teacherClass.getTeam())){ | |
691 | + if(courseNumberChange > maxCourseNumber){ | |
650 | 692 | continue; |
651 | 693 | } |
652 | 694 | if(courseNumberChange < 1){ | ... | ... |
src/main/java/com/jevon/controller/ScheduleInitController.java
... | ... | @@ -86,6 +86,12 @@ public class ScheduleInitController { |
86 | 86 | return baseVo; |
87 | 87 | } |
88 | 88 | |
89 | + @ApiOperation("tset ") | |
90 | + @RequestMapping(value = "test", method = RequestMethod.POST) | |
91 | + public void test(){ | |
92 | + initMessage(1021); | |
93 | + } | |
94 | + | |
89 | 95 | @ApiOperation("更新计划") |
90 | 96 | @RequestMapping(value = "updateSchedule", method = RequestMethod.POST) |
91 | 97 | public BaseVo updateSchedule(@RequestBody UpdateScheduleReqVo updateScheduleReqVo){ |
... | ... | @@ -210,7 +216,8 @@ public class ScheduleInitController { |
210 | 216 | // 获得工作簿 |
211 | 217 | Workbook workbook = null; |
212 | 218 | String file = excelFile.getName(); |
213 | - InputStream inputStream = HttpClientUtils.GetFileInputStream(initTeacherCourseReqVo.getUrl()); | |
219 | + InputStream inputStream = new FileInputStream(excelFile) ; | |
220 | + //InputStream inputStream = HttpClientUtils.GetFileInputStream(initTeacherCourseReqVo.getUrl()); | |
214 | 221 | if(inputStream == null){ |
215 | 222 | baseVo.setMessage("路径不存在"); |
216 | 223 | baseVo.setSuccess(false); | ... | ... |
src/main/java/com/jevon/controller/ScheduleMessageController.java
... | ... | @@ -122,9 +122,30 @@ public class ScheduleMessageController { |
122 | 122 | search.setSingleOrDouble(1); |
123 | 123 | search.setTeam(schedule.getTeam()); |
124 | 124 | classCourseRepVo.setData(classCourseService.selectByClassIdAndSingleOrDouble(search)); |
125 | + List<ClassCourse> list = classCourseService.selectByClassIdAndSingleOrDouble(search); | |
126 | + for(int i = 1 ; i < 6 ; i++){ | |
127 | + System.out.print("周"+i+" "); | |
128 | + for(int j = 1 ; j < 7 ; j++){ | |
129 | + System.out.print(getClassCourse(list,i,j).getCourseName() + " "); | |
130 | + } | |
131 | + System.out.println(); | |
132 | + } | |
125 | 133 | return classCourseRepVo; |
126 | 134 | } |
127 | 135 | |
136 | + //查所在课表中 返回某天某节课 | |
137 | + private ClassCourse getClassCourse(List<ClassCourse> list , int week , int courseNumber){ | |
138 | + ClassCourse result = null ; | |
139 | + for(ClassCourse classCourse : list){ | |
140 | + if(classCourse.getWeek() == week && classCourse.getCourseNumber() == courseNumber){ | |
141 | + result = classCourse ; | |
142 | + break; | |
143 | + } | |
144 | + } | |
145 | + return result; | |
146 | + } | |
147 | + | |
148 | + | |
128 | 149 | @ApiOperation("获取合班信息") |
129 | 150 | @RequestMapping(value = "getJoinList", method = RequestMethod.POST) |
130 | 151 | public JoinRepVo getJoinList(@RequestBody ScheduleIdReqVo scheduleIdReqVo){ | ... | ... |
src/main/java/com/jevon/mapper/TeacherClassMapper.java
1 | 1 | package com.jevon.mapper; |
2 | 2 | |
3 | -import com.jevon.model.Teacher; | |
4 | 3 | import com.jevon.model.TeacherClass; |
5 | 4 | |
6 | 5 | import java.util.List; |
... | ... | @@ -13,21 +12,14 @@ public interface TeacherClassMapper { |
13 | 12 | |
14 | 13 | int insertBatch(List<TeacherClass> teacherClasses); |
15 | 14 | |
16 | - List<TeacherClass> selectByCourseName(TeacherClass teacherClass); | |
17 | - | |
18 | - TeacherClass selectByTeacher(TeacherClass teacherClass); | |
19 | - | |
20 | - TeacherClass selectByCourseAndClass(TeacherClass teacherClass); | |
21 | - | |
22 | - List<TeacherClass> selectBySchoolAndTeam(TeacherClass teacherClass); | |
23 | - | |
24 | 15 | int deleteBySchoolAndTeam(TeacherClass teacherClass); |
25 | 16 | |
26 | - TeacherClass selectById(int tClassId); | |
27 | - | |
28 | 17 | int updateSchedule(int tClassId); |
29 | 18 | |
30 | 19 | int selectHasSchedule(TeacherClass teacherClass); |
31 | 20 | |
32 | 21 | int recallTeacherClass(int tClassId); |
22 | + | |
23 | + | |
24 | + List<TeacherClass> selectByTeacherClass(TeacherClass teacherClass); | |
33 | 25 | } |
34 | 26 | \ No newline at end of file | ... | ... |
src/main/java/com/jevon/service/TeacherClassService.java
src/main/java/com/jevon/service/impl/TeacherClassServiceImpl.java
... | ... | @@ -45,22 +45,41 @@ public class TeacherClassServiceImpl implements TeacherClassService { |
45 | 45 | |
46 | 46 | @Override |
47 | 47 | public List<TeacherClass> selectByCourseName(TeacherClass teacherClass) { |
48 | - return teacherClassMapper.selectByCourseName(teacherClass); | |
48 | + TeacherClass search = new TeacherClass(); | |
49 | + search.setTeam(teacherClass.getTeam()); | |
50 | + search.setSchoolId(teacherClass.getSchoolId()); | |
51 | + search.setCourseName(teacherClass.getCourseName()); | |
52 | + return teacherClassMapper.selectByTeacherClass(search); | |
49 | 53 | } |
50 | 54 | |
51 | 55 | @Override |
52 | 56 | public TeacherClass selectByTeacher(TeacherClass teacherClass) { |
53 | - return teacherClassMapper.selectByTeacher(teacherClass); | |
57 | + TeacherClass search = new TeacherClass(); | |
58 | + search.setTeam(teacherClass.getTeam()); | |
59 | + search.setSchoolId(teacherClass.getSchoolId()); | |
60 | + search.setCourseName(teacherClass.getCourseName()); | |
61 | + search.setTeacherName(teacherClass.getTeacherName()); | |
62 | + search.setClassId(teacherClass.getClassId()); | |
63 | + return teacherClassMapper.selectByTeacherClass(search).get(0); | |
54 | 64 | } |
55 | 65 | |
56 | 66 | @Override |
57 | 67 | public TeacherClass selectByCourseAndClass(TeacherClass teacherClass) { |
58 | - return teacherClassMapper.selectByCourseAndClass(teacherClass); | |
68 | + TeacherClass search = new TeacherClass(); | |
69 | + search.setTeam(teacherClass.getTeam()); | |
70 | + search.setSchoolId(teacherClass.getSchoolId()); | |
71 | + search.setCourseName(teacherClass.getCourseName()); | |
72 | + search.setGrade(teacherClass.getGrade()); | |
73 | + search.setClassId(teacherClass.getClassId()); | |
74 | + return teacherClassMapper.selectByTeacherClass(search).get(0); | |
59 | 75 | } |
60 | 76 | |
61 | 77 | @Override |
62 | 78 | public List<TeacherClass> selectBySchoolAndTeam(TeacherClass teacherClass) { |
63 | - return teacherClassMapper.selectBySchoolAndTeam(teacherClass); | |
79 | + TeacherClass search = new TeacherClass(); | |
80 | + search.setTeam(teacherClass.getTeam()); | |
81 | + search.setSchoolId(teacherClass.getSchoolId()); | |
82 | + return teacherClassMapper.selectByTeacherClass(search); | |
64 | 83 | } |
65 | 84 | |
66 | 85 | @Override |
... | ... | @@ -70,7 +89,9 @@ public class TeacherClassServiceImpl implements TeacherClassService { |
70 | 89 | |
71 | 90 | @Override |
72 | 91 | public TeacherClass selectById(int tClassId) { |
73 | - return teacherClassMapper.selectById(tClassId); | |
92 | + TeacherClass search = new TeacherClass(); | |
93 | + search.settClassId(tClassId); | |
94 | + return teacherClassMapper.selectByTeacherClass(search).get(0); | |
74 | 95 | } |
75 | 96 | |
76 | 97 | @Override |
... | ... | @@ -90,4 +111,18 @@ public class TeacherClassServiceImpl implements TeacherClassService { |
90 | 111 | public int recallTeacherClass(int tClassId) { |
91 | 112 | return teacherClassMapper.recallTeacherClass(tClassId); |
92 | 113 | } |
114 | + | |
115 | + @Override | |
116 | + public int selectTeacherDayClass(int schoolId, String team, String teacherName) { | |
117 | + TeacherClass search = new TeacherClass() ; | |
118 | + search.setSchoolId(schoolId); | |
119 | + search.setTeam(team); | |
120 | + search.setTeacherName(teacherName); | |
121 | + List<TeacherClass> list = teacherClassMapper.selectByTeacherClass(search); | |
122 | + int sumClassNumber = 0 ; | |
123 | + for(TeacherClass teacherClass :list){ | |
124 | + sumClassNumber += teacherClass.getTimes(); | |
125 | + } | |
126 | + return (sumClassNumber/5) +1; | |
127 | + } | |
93 | 128 | } | ... | ... |
src/main/java/com/jevon/vo/req/ParallelClassReqVo.java
src/main/resources/application.yml
... | ... | @@ -3,12 +3,12 @@ server: |
3 | 3 | |
4 | 4 | spring: |
5 | 5 | datasource: |
6 | -# username: SZJXTUSER | |
7 | -# password: xst200919 | |
8 | -# url: jdbc:sqlserver://60.190.202.57:14333;database=SmartPaike | |
9 | - username: szjxtuser | |
10 | - password: RQminVCJota3H1u8bBYH | |
11 | - url: jdbc:sqlserver://116.62.241.27:33419;database=SmartCampus_java | |
6 | + username: SZJXTUSER | |
7 | + password: xst200919 | |
8 | + url: jdbc:sqlserver://60.190.202.57:14333;database=SmartPaike | |
9 | +# username: szjxtuser | |
10 | +# password: RQminVCJota3H1u8bBYH | |
11 | +# url: jdbc:sqlserver://116.62.241.27:33419;database=SmartCampus_java | |
12 | 12 | driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver |
13 | 13 | filters: stat |
14 | 14 | maxActive: 20 | ... | ... |
src/main/resources/mapping/TeacherClassMapper.xml
... | ... | @@ -41,10 +41,6 @@ |
41 | 41 | </foreach> |
42 | 42 | </insert> |
43 | 43 | |
44 | - <select id="selectById" parameterType="java.lang.Integer" resultMap="BaseResultMap"> | |
45 | - select * from sz_sch_teacher_class where t_class_id =#{tClassId} | |
46 | - </select> | |
47 | - | |
48 | 44 | <select id="selectHasSchedule" parameterType="com.jevon.model.TeacherClass" resultType="java.lang.Integer"> |
49 | 45 | select count(status) from sz_sch_teacher_class where school_id = #{schoolId} and team = #{team} and status=1 |
50 | 46 | </select> |
... | ... | @@ -56,30 +52,37 @@ |
56 | 52 | update sz_sch_teacher_class set status = 0 where t_class_id =#{tClassId} |
57 | 53 | </update> |
58 | 54 | |
59 | - <select id="selectBySchoolAndTeam" parameterType="com.jevon.model.TeacherClass" resultMap="BaseResultMap"> | |
60 | - select * from sz_sch_teacher_class where team =#{team} and school_id = #{schoolId} | |
61 | - </select> | |
62 | 55 | <delete id="deleteBySchoolAndTeam" parameterType="com.jevon.model.TeacherClass"> |
63 | 56 | delete from sz_sch_teacher_class where team =#{team} and school_id = #{schoolId} |
64 | 57 | </delete> |
65 | 58 | |
66 | - <select id="selectByCourseName" parameterType="com.jevon.model.TeacherClass" resultMap="BaseResultMap"> | |
67 | - select * from sz_sch_teacher_class where team =#{team} and school_id = #{schoolId} and course_name = #{courseName} | |
59 | + <select id="selectByTeacherClass" parameterType="java.lang.Integer" resultMap="BaseResultMap"> | |
60 | + select * from sz_sch_teacher_class | |
61 | + <where> | |
62 | + <if test="tClassId != null and tClassId != 0"> | |
63 | + and t_class_id =#{tClassId} | |
64 | + </if> | |
65 | + <if test="schoolId != null"> | |
66 | + and school_id = #{schoolId} | |
67 | + </if> | |
68 | + <if test="team != null"> | |
69 | + and team =#{team} | |
70 | + </if> | |
71 | + <if test="courseName != null"> | |
72 | + and course_name = #{courseName} | |
73 | + </if> | |
74 | + <if test="teacherName != null"> | |
75 | + and teacher_name = #{teacherName} | |
76 | + </if> | |
77 | + <if test="grade != null"> | |
78 | + and grade = #{grade} | |
79 | + </if> | |
80 | + <if test="classId != null"> | |
81 | + and class_id =#{classId} | |
82 | + </if> | |
83 | + </where> | |
68 | 84 | </select> |
69 | 85 | |
70 | - <select id="selectByCourseAndClass" parameterType="com.jevon.model.TeacherClass" resultMap="BaseResultMap"> | |
71 | - select * from sz_sch_teacher_class where team =#{team} and school_id = #{schoolId} and course_name = #{courseName} | |
72 | - <if test="grade != null"> | |
73 | - and grade = #{grade} | |
74 | - </if> | |
75 | - <if test="classId != 0"> | |
76 | - and class_id =#{classId} | |
77 | - </if> | |
78 | - </select> | |
79 | - | |
80 | - <select id="selectByTeacher" parameterType="com.jevon.model.TeacherClass" resultMap="BaseResultMap"> | |
81 | - select * from sz_sch_teacher_class where team =#{team} and school_id= #{schoolId} and teacher_name = #{teacherName} and class_id = #{classId} | |
82 | - </select> | |
83 | 86 | <update id="updateByPrimaryKey" parameterType="com.jevon.model.TeacherClass" > |
84 | 87 | update sz_sch_teacher_class |
85 | 88 | set teacher_id = #{teacherId,jdbcType=INTEGER}, |
... | ... | @@ -94,115 +97,4 @@ |
94 | 97 | where t_class_id = #{tClassId,jdbcType=INTEGER} |
95 | 98 | </update> |
96 | 99 | |
97 | - <!-- <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >--> | |
98 | - <!-- select --> | |
99 | - <!-- <include refid="Base_Column_List" />--> | |
100 | - <!-- from sz_sch_teacher_class--> | |
101 | - <!-- where t_class_id = #{tClassId,jdbcType=INTEGER}--> | |
102 | - <!-- </select>--> | |
103 | - <!-- <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer" >--> | |
104 | - <!-- delete from sz_sch_teacher_class--> | |
105 | - <!-- where t_class_id = #{tClassId,jdbcType=INTEGER}--> | |
106 | - <!-- </delete>--> | |
107 | -<!-- <insert id="insertSelective" parameterType="com.jevon.model.TeacherClass" >--> | |
108 | -<!-- insert into sz_sch_teacher_class--> | |
109 | -<!-- <trim prefix="(" suffix=")" suffixOverrides="," >--> | |
110 | -<!-- <if test="tClassId != null" >--> | |
111 | -<!-- t_class_id,--> | |
112 | -<!-- </if>--> | |
113 | -<!-- <if test="teacherId != null" >--> | |
114 | -<!-- teacher_id,--> | |
115 | -<!-- </if>--> | |
116 | -<!-- <if test="teacherName != null" >--> | |
117 | -<!-- teacher_name,--> | |
118 | -<!-- </if>--> | |
119 | -<!-- <if test="schoolId != null" >--> | |
120 | -<!-- school_id,--> | |
121 | -<!-- </if>--> | |
122 | -<!-- <if test="grade != null" >--> | |
123 | -<!-- grade,--> | |
124 | -<!-- </if>--> | |
125 | -<!-- <if test="classId != null" >--> | |
126 | -<!-- class_id,--> | |
127 | -<!-- </if>--> | |
128 | -<!-- <if test="courseName != null" >--> | |
129 | -<!-- course_name,--> | |
130 | -<!-- </if>--> | |
131 | -<!-- <if test="times != null" >--> | |
132 | -<!-- times,--> | |
133 | -<!-- </if>--> | |
134 | -<!-- <if test="joinTimes != null" >--> | |
135 | -<!-- join_times,--> | |
136 | -<!-- </if>--> | |
137 | -<!-- <if test="createTime != null" >--> | |
138 | -<!-- create_time,--> | |
139 | -<!-- </if>--> | |
140 | -<!-- </trim>--> | |
141 | -<!-- <trim prefix="values (" suffix=")" suffixOverrides="," >--> | |
142 | -<!-- <if test="tClassId != null" >--> | |
143 | -<!-- #{tClassId,jdbcType=INTEGER},--> | |
144 | -<!-- </if>--> | |
145 | -<!-- <if test="teacherId != null" >--> | |
146 | -<!-- #{teacherId,jdbcType=INTEGER},--> | |
147 | -<!-- </if>--> | |
148 | -<!-- <if test="teacherName != null" >--> | |
149 | -<!-- #{teacherName,jdbcType=VARCHAR},--> | |
150 | -<!-- </if>--> | |
151 | -<!-- <if test="schoolId != null" >--> | |
152 | -<!-- #{schoolId,jdbcType=INTEGER},--> | |
153 | -<!-- </if>--> | |
154 | -<!-- <if test="grade != null" >--> | |
155 | -<!-- #{grade,jdbcType=INTEGER},--> | |
156 | -<!-- </if>--> | |
157 | -<!-- <if test="classId != null" >--> | |
158 | -<!-- #{classId,jdbcType=INTEGER},--> | |
159 | -<!-- </if>--> | |
160 | -<!-- <if test="courseName != null" >--> | |
161 | -<!-- #{courseName,jdbcType=VARCHAR},--> | |
162 | -<!-- </if>--> | |
163 | -<!-- <if test="times != null" >--> | |
164 | -<!-- #{times,jdbcType=INTEGER},--> | |
165 | -<!-- </if>--> | |
166 | -<!-- <if test="joinTimes != null" >--> | |
167 | -<!-- #{joinTimes,jdbcType=INTEGER},--> | |
168 | -<!-- </if>--> | |
169 | -<!-- <if test="createTime != null" >--> | |
170 | -<!-- #{createTime,jdbcType=TIMESTAMP},--> | |
171 | -<!-- </if>--> | |
172 | -<!-- </trim>--> | |
173 | -<!-- </insert>--> | |
174 | -<!-- <update id="updateByPrimaryKeySelective" parameterType="com.jevon.model.TeacherClass" >--> | |
175 | -<!-- update sz_sch_teacher_class--> | |
176 | -<!-- <set >--> | |
177 | -<!-- <if test="teacherId != null" >--> | |
178 | -<!-- teacher_id = #{teacherId,jdbcType=INTEGER},--> | |
179 | -<!-- </if>--> | |
180 | -<!-- <if test="teacherName != null" >--> | |
181 | -<!-- teacher_name = #{teacherName,jdbcType=VARCHAR},--> | |
182 | -<!-- </if>--> | |
183 | -<!-- <if test="schoolId != null" >--> | |
184 | -<!-- school_id = #{schoolId,jdbcType=INTEGER},--> | |
185 | -<!-- </if>--> | |
186 | -<!-- <if test="grade != null" >--> | |
187 | -<!-- grade = #{grade,jdbcType=INTEGER},--> | |
188 | -<!-- </if>--> | |
189 | -<!-- <if test="classId != null" >--> | |
190 | -<!-- class_id = #{classId,jdbcType=INTEGER},--> | |
191 | -<!-- </if>--> | |
192 | -<!-- <if test="courseName != null" >--> | |
193 | -<!-- course_name = #{courseName,jdbcType=VARCHAR},--> | |
194 | -<!-- </if>--> | |
195 | -<!-- <if test="times != null" >--> | |
196 | -<!-- times = #{times,jdbcType=INTEGER},--> | |
197 | -<!-- </if>--> | |
198 | -<!-- <if test="joinTimes != null" >--> | |
199 | -<!-- join_times = #{joinTimes,jdbcType=INTEGER},--> | |
200 | -<!-- </if>--> | |
201 | -<!-- <if test="createTime != null" >--> | |
202 | -<!-- create_time = #{createTime,jdbcType=TIMESTAMP},--> | |
203 | -<!-- </if>--> | |
204 | -<!-- </set>--> | |
205 | -<!-- where t_class_id = #{tClassId,jdbcType=INTEGER}--> | |
206 | -<!-- </update>--> | |
207 | - | |
208 | 100 | </mapper> |
209 | 101 | \ No newline at end of file | ... | ... |