前端页面多个选择器返回api接口的sql查询高效写法

表单查询过滤时,一般前端会有多个Select选择器进行下拉选择进行查询,为了减少接口请求的次数,我一般设计的时候,会尽量把下拉选择器的list数据,都汇总在一个接口,进行返回。

样式引用elementUI中的Selcet选择器,如下: 

 

 

 

-- 多个选择器下拉框汇总sql
WITH tab as (
select project from PROBLEM_MANAGE_F group by project
),
tab0 as (
select PROCESS from PROBLEM_MANAGE_F group by PROCESS
),
tab1 as (
select PRODUCT from PROBLEM_MANAGE_F group by PRODUCT
),
tab2 as (
select concat('PROJECT:','[',group_concat(project),']') as project from tab
),
tab3 as 
(
select concat('PRODUCT:','[',group_concat(PRODUCT),']') as PRODUCT from tab1
)
,
tab4 as 
(
select concat('PROCESS:','[',group_concat(PROCESS),']') as PROCESS from  tab0
)
select *from tab4,tab3,tab2 ;

实例sql中,运用了mysql8的新特性,with as 表达式表示临时表,可以把多个sql语句进行拼接使用,这里简单讲下,表单中有三列字段,是业务常用的下拉筛选,如 项目、工序、产品,通过对表单中的数据,先进行group by分组,以临时表的形式表示tab,tab0,tab1,然后再通过group_contact函数,合并每个字段的内容在一行,即将分组后可能有多个产品值,如:产品A,产品B,产品C合并(默认是逗号隔开),然后为了返回给前端更好地取值,还可以通过concat函数拼接一个固定的key值,形成如:{"PROJECT":["产品A","产品B","产品C"]}

 如上的例子,查询得到的结果就只有一条数据,三个字段,PROJECT,PRODUCT,PROCESS,内容分别就是原表对应的字段分组后用逗号拼接的多个值。

XML中的返回值就可以定义为Map类型

<select id="getSearchDropDownList" resultType="java.util.Map">

Mapper中的方法返回值,因为数据只有一条所以可以直接返回Map

public Map<String,List<String>> getSearchDropDownList();

另外如果xml返回的是Map,数据有多条情况下,Mapper对应的方法的返回值则需要用List

public Lsit<Map<String,Object>> getSearchDropDownList();

List中再嵌套List,业务场景中需要注意,有时会报错没有这种参数类型支持

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值