JAVA之Mysql应用|记一次通过mysql表中的三个字段对应一个前端组合状态字段查询场景的解决方案

一、需求背景

最近项目有一个需求,产品要求在查询活动数据的时候,需要支持状态枚举字段的多选查询。活动状态有: 待审核、审核不通过、待投放、投放中、投放完成、已删除 这6种状态。

二、需求可行性

1、现状描述

产品要求支持多选的活动枚举状态有: 待审核、审核不通过、待投放、投放中、投放完成、已删除这6种状态。
系统的表结构现状:

审核字段: approval_state      { 1:待审核 2:审核通过 3:审核不通过 }
投放字段:launch_state         { 1:待投放 2:投放中 3:投放完成 }
删除字段:state                { 1:正常 0:已删除 }

2、可行性分析

前端的“状态”字段是一个统一的字段。 我们不妨定义为 composedState 。
后端的“状态”字段实际上是有3个,就是上面所说的“审核字段”、“投放字段”、“删除字段”这三种。
我们可以给定composedState多个枚举状态,不妨给定:

composedState == 6  已删除
composedState == 5  投放完成
composedState == 4  投放中
composedState == 3  待投放
composedState == 2  审核不通过
composedState == 1  待审核

由此,可以满足我们的需要。

三、细节分析

关于上面几个字段,它们之间是存在一定的联系的。
首先,想要展示“审核状态”、“投放状态”,首先要保证数据是正常的,而不是已删除状态,这是一个大前提;
然后,如果想要展示“投放状态”,那么前置条件一定是,审核状态:审核通过。

换句话说,待投放、投放中、投放完成这些状态的活动,他们呢一定是审核通过的活动;
显示为待审核、审核不通过的活动,他们一定是正常的没有被删除的活动。环环相扣。

只有满足了以上两点,才是符合我们想要的业务逻辑的。

四、解决方案

1、前端逻辑

主要是下面几个枚举状态的传参约定:

composedState == 6  已删除
composedState == 5  投放完成
composedState == 4  投放中
composedState == 3  待投放
composedState == 2  审核不通过
composedState == 1  待审核

2、后端处理逻辑

f(null != creativityListDTO.getComposedStates()) //处理前端入参
{ 
	String[] composedStates = creativityListDTO.getComposedStates().split(","); //前端的字段是一个字符串,我们对其进行切割
	List<Integer> composedStatesList = new ArrayList<>(); 
	if(0< composedStates.length)
	{ 
		for(int i=0;i<composedStates.length;i++) 
		{ 
			if(!("").equals(composedStates[i]))
				{ 
					composedStatesList.add(i,Integer.valueOf(composedStates[i])); 
				} 
		} 
		map.put("composedStatesList",composedStatesList); 
	} 
}

3、后端sql

<if test="null != composedStatesList and composedStatesList.size() > 0"> 
AND 
( 
	(1!=1) 
	<foreach collection="composedStatesList" item="item"> 
		<if test="item == 1"> 
			OR ( a.state IN (1) AND a.approval_state IN (1) ) 
		</if> 
		<if test="item == 2"> 
			OR ( a.state IN (1) AND a.approval_state IN (3) ) 
		</if> 
		<if test="item == 3"> 
			OR ( a.state IN (1) AND a.approval_state IN (2) AND c.launch_state IN (1)) 
		</if> 
		<if test="item == 4"> 
			OR ( a.state IN (1) AND a.approval_state IN (2) AND c.launch_state IN (2) ) 
		</if> 
		<if test="item == 5"> 
			OR ( a.state IN (1) AND a.approval_state IN (2) AND c.launch_state IN (3) ) 
		</if> 
		<if test="item == 6"> 
			OR ( a.state IN (0) ) 
		</if> 
	</foreach> 
) 
</if>

4、sql小细节—— (1!=1)

sql里面有一个条件,(1!=1) ,这是一个false,意义在哪里呢?
比如我们跟前端约定了枚举值1、2、3、4、5、6,这个时候如惨楚然冒出来一个7,那么这个时候必然是不能查询出相关数据的,因此我们需要在这里设定一个false,当如惨超出我们约定好的参数取值范围之后,查询条件必须返回false,也即这个时候是查询不到任何数据的,也是符合常理的,所以我们添加了 (1!=1)

五、结论

大功告成!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北溟南风起

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值