主要是用GROUP BY 加上GROUP_CONCAT函数来实现的
sql为:select a.majortree_code, GROUP_CONCAT(b.majortree_code) r1, GROUP_CONCAT(LENGTH(b.majortree_code)) r2, b.majortree_code, GROUP_CONCAT(case LENGTH(b.majortree_code) when 3 then b.majortree_code else null end) a1, GROUP_CONCAT(case LENGTH(b.majortree_code) when 6 then b.majortree_code else null end) b2, GROUP_CONCAT(case LENGTH(b.majortree_code) when 9 then b.majortree_code else null end) c3 FROM zj_bdexpertmajor a JOIN zj_bdexpertmajor b on a.majortree_code like CONCAT(b.majortree_code,'%') GROUP BY a.majortree_code ORDER BY a.majortree_code
下面是查出来的数据 如果需要显示名称就b.name
JOIN zj_bdexpertmajor b on a.majortree_code like CONCAT(b.majortree_code,‘%’)
这段sql的意思是 把a表的code 跟全表的b.code比较 有满足的就拿出来
如果a表的code是 001003001 b表就会 001003001like 001 满足 001003也满足 001003001也满足 这样b表就有了三条数据 然后用LENGTH() 函数把字符值变为字符的长度值再用GROUP_CONCAT 把所有的字符的长度值拿出来就变成了
然后再用case when 判断字符长度3为一级 6为2级
核心就是group by
如果不用length和 case when的话就是这样的数据