MySQL巧用FIND_IN_SET和GROUP_CONCAT函数减少Java代码量
数据库表简介:物品表
`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级物品集合
>>>>>>>>>>>>>>>>>>>>>>>>solution>>>>>>>>>>>>>>>>>>>>>>>>>>>
问题2:首先利用问题一种所查信息获取所有的parentId
select distinct g.parentId from good g where FIND_IN_SET(g.id,(select childIds from good where id =1))
既然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
再使用问题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))
总结:在一般的表格带参数查询的函数中,可以先想想如何利用sql查询出所预期的结果,避免大规模的使用Java代码进行循环遍历。嗯,真香~
最新文章
- SharePoint 2013 页面访问,Url中间多一段";_layouts/15/start.aspx#";
- Cannot find `aapt.exe`. Please install the Android SDK Build-tools package
- linux之基础命令大全
- [logstash-input-log4j]插件使用详解
- JavaScript数独求解器
- fzuoj Problem 2182 水题
- svn搭建以及可能遇到的问题解决方案
- shell中cut用法
- 最牛叉的街机游戏合集 &; 模拟器
- 不同系统平台下Java默认的安装路径
- hdu 4412 利用单调性的动态规划
- java001-Helloworld
- C# gridview分頁導出excel
- 常用sql语句及案例(oracle)
- cURL实现get、post请求
- 日常API之C#百度人脸识别
- 【APS.NET 框架系列】浅谈ASP.NET 框架
- Hibernate(4)简单的HelloWorld
- 【转】MySQL 当记录不存在时insert,当记录存在时update
- 关于webpack,babel,以及es6和commonJS之间的联系(转)
热门文章
- eclipse maven程序包org.junit不存在
- java多线程之守护线程与非守护线程
- Qt 学习(4)
- Graphics绘制类及打印机设置相关
- hibernate课程 初探单表映射4-1 课程总结
- MySQL(三) 完整性约束
- Python函数(2)
- 如何找到Android app启动activity和页面元素信息
- php的yii框架开发总结7
- 创建Gradle工程出现Could not install Gradle distribution from 'https://services.gradle.org/distributions/gradleXX'.问题解决