首页 >后端开发 >php教程 >SQL查询排序有关问题

SQL查询排序有关问题

WBOY
WBOY原创
2016-06-13 10:51:39740浏览

SQL查询排序问题
SELECT * , group_concat( ' ' , concat_ws( ' X ', `sku` , `quantity-purchased` ) , ' ' ),group_concat(' ' , `order_id` , ' ') FROM ( select * from `sale_orders` order by `sku`) T WHERE `shipments` =0 AND `number` =$id GROUP BY `recipient-name` , `ship-address-1` ORDER BY `sku`

以下为查询的结果:

ship name sku-quantity
001-01 wang A0015-00-04-23 X 1  
002-02 liu A0041-00-WW-25 X 1 , A0042-00-AC-25 X 1  
003-03 li A0041-00-WW-25 X 1 , A0042-00-AC-25 X 1 , A0256-00-O6-34 X 1 
004-04 fang A0041-00-WW-25 X 1 ,A0042-00-AC-25 X 1 , A0217-00-SI-33 X 1 

请问怎么在此基础上再按sku-quantity字段的SKU个数来排序(就是字符串长度)

------解决方案--------------------
试试 ..... order by count(sku)
------解决方案--------------------
你这个group_concat( ' ' , concat_ws( ' X ', `sku` , `quantity-purchased` ) , ' ' ),group_concat(' ' , `order_id` , ' ')

两个group_concat, 
和你的结果
ship name sku-quantity
001-01 wang A0015-00-04-23 X 1
002-02 liu A0041-00-WW-25 X 1 , A0042-00-AC-25 X 1
里怎么对应? 

哪个是shu-quantity?

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn