postgresql多选功能实现代码

来自:网络
时间:2024-08-28
阅读:
免费资源网 - https://freexyz.cn/

一、背景介绍

在一所乡村小学,教师资源紧张,所以会出现一个教师身兼多职的情况,既是语文老师又是数学老师甚至还是体育老师,这个系统就是为各个班级分配老师,这样一个场景实现

二、代码实现及效果

后端country_teacher表数据和表结构:

postgresql多选功能实现代码

前端大概页面:

postgresql多选功能实现代码

学科中英文对照表:前端传的是带中括号的英文,后端数据库存的是中文

美术语文英语数学体育
ArtChineseEnglishMathSport

由于前端勾选科目的时候是多选框,所以会有顺序的问题,比如说用户先勾选了英语再勾选了美术,那么后端接收到的参数就是

[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 '体育'
        }
    }
}

最终效果就是这样:
用户勾选了美术,那么下方就显示所有教美术的老师,即张三、赵六、唐八三位老师

postgresql多选功能实现代码

用户勾选了英语、体育,那么下方就显示所有教英语和体育的老师,即王五、唐八两位老师

postgresql多选功能实现代码

免费资源网 - https://freexyz.cn/
返回顶部
顶部