数据库表简介:物品表

`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代码进行循环遍历。嗯,真香~

MySQL巧用FIND_IN_SET和GROUP_CONCAT函数减少Java代码量的更多相关文章

  1. Java基础学习总结(81)——如何尽可能的减少Java代码中bug

    Java编程语言的人气自然无需质疑,从Web应用到Android应用,这款语言已经被广泛用于开发各类应用及代码中的复杂功能. 不过在编写代码时,bug永远是困扰每一位从业者的头号难题.在今天的文章中, ...

  2. mysql数据库的连接以及增删改查Java代码实现(转载)

    每天叫醒自己的不是闹钟,而是梦想 数据库: create table t1(id int primary key not null auto_increment,name varchar(32),pa ...

  3. MySQL中好用的GROUP_CONCAT函数

    今天看到同事的代码,又学到了一个有用的函数,刚看的时候不太懂,就搜了下用法,看下面这篇文章讲的挺详细就直接转载了,我也写不那么好,呵呵,感谢作者的无私奉献. http://blog.sina.com. ...

  4. MySQL中使用group_concat()函数数据字符过长报错的问题解决方法

    最近在办公软件项目,在开发权限指标遇到一个问题:我们系统的一些逻辑处理是用存储过程实现的,但是有一天客户反馈说权限指标分配报错,查了分配的权限数据牵扯到的数据权限基础资源,没有问题.权限指标分配的存储 ...

  5. MySQL中使用group_concat()函数数据被截取(有默认长度限制),谨慎!

    最近在工作中遇到一个问题: 我们系统的一些逻辑处理是用存储过程实现的,但是有一天客服反馈说订单下单失败,查了下单牵扯到的产品基础资源,没有问题. 下单的存储过程中有这样两句代码: ; ; ; 执行存储 ...

  6. MySQL在使用group_concat()函数数据被截取

    遇到问题: 项目中有个需求,MySQL中存储的是树状的数据.现在给出一个节点,需要从Mysql数据库中取出这个节点下所有的节点.采用MySQL的函数. 函数如下: CREATE DEFINER=`ro ...

  7. Mysql中使用find_in_set函数查找字符串

    mysql有个表的字段的存储是以逗号分隔的,如domain字段login.s01.yy.com,s01.yy.com,s02.yy.com.现在要查找s01.yy.com这个.我们用like查找好像不 ...

  8. group_concat函数与find_in_set()函数相结合

    一:group_concat函数详解 1.语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'] ...

  9. 教您如何使用MySQL group_concat函数

    MySQL group_concat函数是典型的字符串连接函数,下面就为您介绍MySQL group_concat的语法,希望对您学习MySQL group_concat函数有所帮助. MySQL g ...

随机推荐

  1. 为什么阿里云服务器的docker启动tomcat这么慢??

    https://blog.csdn.net/tianyiii/article/details/79314597 最近在阿里云服务器使用Docker启动Tomcat,发现tomcat服务器启动过程很慢. ...

  2. Apache-ant安装以及环境变量配置、验证

    (一)安装 ant 下载地址: http://ant.apache.org/     根据自己电脑下载对应版本 下载完成以后,可自行解压到自己常用的盘中,但是要记住解压到哪里了,以便后续的环境变量配置 ...

  3. python 3.6 链接mssql 进行数据操作

    #!/usr/bin/env python # -*- coding: UTF-8 -*- import pymssql class MSSQL(object): ''' 对pymssql的简单封装 ...

  4. Cookie概述

    一.什么叫Cookie? Cookie翻译成中文是小甜点,小饼干,在Http中它表示服务器送给客户端浏览器的小甜点.其实Cookie就是一个键和一个值构成,随着服务器端的响应发送给客户端浏览器,然后客 ...

  5. 使用C#实现计划任务(corn job)

    维基百科上是这样描述计划任务的: “Cron is a time-based job scheduler in Unix-like computer operating systems. Cron i ...

  6. SQL2008R2 清空日志

    SQLSERVER2008之前版本执行的SQL语句: DUMP TRAN 数据库名 WITH NO_LOG SQLSERVER2008-R2版本执行的SQL语句: ALTER DATABASE 数据库 ...

  7. count group by 组合用法

    1 需求是 求订单表1个月内 订单累计费用超过500的有多少人 根据题意 最先写出的sql是这样的 SELECT SUM(totalfee)AS n FROM sendorder WHERE `add ...

  8. django choice字段模板展示

    class UserInfo(AbstractUserInfo): """ 用户表 """ gender_choice = ( (1,&qu ...

  9. Java问题定位之如何借助线程堆栈进行问题分析

    在大型的应用中,线程堆栈打印出来特别多,如何从众多的信息中找到真正有用,有价值的信息,我们需要一定的技巧.本文对此详细介绍. 我们可以从三个方面分析:堆栈的局部信息,一次堆栈的统计信息,多个堆栈的对比 ...

  10. SourceTree Win10 安装过程及配置

    SourceTree 是一款拥有可视化界面的项目版本控制软件,适用于git项目管理,同时它集成了 git flow 工作流程,对于不熟悉 git 命令的初学者来说,可以通过 SourceTree 快速 ...