mysql set j_MySQL巧用FIND_IN_SET和GROUP_CONCAT函数减少Java代码量

数据库表简介:物品表

e5054813f87979fcacca89c896209dc7.png

`id` int(11)    '物品id,唯一标识',

`name` varchar(255)   '物品名称',

`level` int(11)   '物品类别等级,礼品包为最高级1,类别为2级,详细物品为3级',

`parentId` int(11)  '只有3级详细物品有上级id',

`childIds` varchar(255)    '只有1级礼品包级有包含所有3级物品id的字符串,id之间用","隔开',

问题描述:利用sql语句简化代码,让Java代码可以直接通过jdbc查询获取下述集合

1、根据输入的1级的id查询其包含的所有3级物品信息

2、根据输入的1级的id查询其包含的所有3级物品对应的2级物品类别信息

>>>>>>>>>>>>>>>>>>>>>>>>solution>>>>>>>>>>>>>>>>>>>>>>>>>>>

问题1:因为in(childIds)使用针对字符串不能遍历childIds中所有id,又要避免在Java代码中先获取childIds,再split(",")之后循环获取对应good对象。巧妙利用childIds字段中id用","隔开的特性,所有使用FIND_IN_SET(id,str)函数。

select g.* from good g where FIND_IN_SET(g.id,(select childIds from good where id =1));    #假设输入1级id为1

查询结果:返回1级下所有3级物品集合

58b7980407a77a1efec25e840fb00f9e.png

>>>>>>>>>>>>>>>>>>>>>>>>solution>>>>>>>>>>>>>>>>>>>>>>>>>>>

问题2:首先利用问题一种所查信息获取所有的parentId

select distinct g.parentId from good g where FIND_IN_SET(g.id,(select childIds from good where id =1))

d0d01f135850f02da17e5bfeb8455389.png

既然parentId都已经查出来了,按以往办法先获取所有parentId集合,再遍历查询出所有该1级childIds中的3级物品对应的2级物品类别信息。解决办法使用GROUP_CONCAT(id)将所查parentId拼接成"3,4,5"这样的字符串。

先看看GROUP_CONCAT的用法:

select GROUP_CONCAT(L2ids.parentId) from

(select distinct g.parentId from good g where FIND_IN_SET(g.id,(select childIds from good where id =1))) L2ids

1a6b8be76294f5adb105a3e9007c0762.png

再使用问题1中的解决办法查询所有2级物品信息:

select g.* from good g where FIND_IN_SET(g.id,

(select GROUP_CONCAT(L2ids.parentId) from

(select distinct g.parentId from good g where FIND_IN_SET(g.id,(select childIds from good where id =1))) L2ids))

915c39a39c251a422e170894f8ebf9c4.png

总结:在一般的表格带参数查询的函数中,可以先想想如何利用sql查询出所预期的结果,避免大规模的使用Java代码进行循环遍历。嗯,真香~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值