一、背景介绍
在一所乡村小学,教师资源紧张,所以会出现一个教师身兼多职的情况,既是语文老师又是数学老师甚至还是体育老师,这个系统就是为各个班级分配老师,这样一个场景实现
二、代码实现及效果
后端country_teacher表数据和表结构:
前端大概页面:
学科中英文对照表:前端传的是带中括号的英文,后端数据库存的是中文
美术 | 语文 | 英语 | 数学 | 体育 |
---|---|---|---|---|
Art | Chinese | English | Math | Sport |
由于前端勾选科目的时候是多选框,所以会有顺序的问题,比如说用户先勾选了英语再勾选了美术,那么后端接收到的参数就是
[English][Art]
所以后端要做一个排序处理,就是做到不管前端传的顺序是什么,后端最终都是固定的顺序,同时保证在数据库中教师对应的科目字段顺序也是固定的,比如说这个教师教了英语和美术,那么数据库里存的就是
美术,英语
因为是按照它们的英文首字母升序排序的
以下为后端关键代码,语言为 groovy,和 java 类似:
def main(){ // def job = values['job'] // 入参 def job = "[Chinese][Math][English][Art][Sport]" // 模拟入参 if(job == null || job == ''){ return null } // 转义,添加逗号,分割为数组 def nJob = job.replaceAll('\\]\\[','\\],\\[') def jobArr = nJob.split(',') // 对数组进行首字母排序, def sortArr = jobArr.sort() def nArr = [] sortArr.eachWithIndex{ it,i -> { // 删除掉[] def item = it.replaceAll('\\]','').replaceAll('\\[','') // 从枚举中获取中文对应学科名 nArr[i] = Job[item.toUpperCase()].name } } // 定义模糊查询条件 def likeJob = '' nArr.each{ likeJob += '%' + it } likeJob = likeJob + "%" // dbUtil是数据库工具类,自行封装即可 return dbUtil.findBySql("select name,subject,id,username from country_teacher where deleted = 0"+ " and subject like ('$likeJob')") } enum Job { ART, CHINESE, ENGLISH, MATH, SPORT String getName() { switch (this) { case ART: return '美术' case CHINESE: return '语文' case ENGLISH: return '英语' case MATH: return '数学' case SPORT: return '体育' } } }
最终效果就是这样:
用户勾选了美术,那么下方就显示所有教美术的老师,即张三、赵六、唐八三位老师
用户勾选了英语、体育,那么下方就显示所有教英语和体育的老师,即王五、唐八两位老师