一、背景介绍
在一所乡村小学,教师资源紧张,所以会出现一个教师身兼多职的情况,既是语文老师又是数学老师甚至还是体育老师,这个系统就是为各个班级分配老师,这样一个场景实现
二、代码实现及效果
后端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, SPORTString getName() {switch (this) {case ART: return '美术'case CHINESE: return '语文'case ENGLISH: return '英语'case MATH: return '数学'case SPORT: return '体育'}}
}
最终效果就是这样:
用户勾选了美术,那么下方就显示所有教美术的老师,即张三、赵六、唐八三位老师
用户勾选了英语、体育,那么下方就显示所有教英语和体育的老师,即王五、唐八两位老师