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