>백엔드 개발 >PHP 튜토리얼 >mysql order by语句,无限分类问题

mysql order by语句,无限分类问题

WBOY
WBOY원래의
2016-06-06 20:42:321141검색

老师请帮忙看看?
无限分类里里面的同级分类如何实现再排序

<code>SELECT `DishCategory_Path`,`DishCategory_Name`,`DishCategory_Sort`,concat(`DishCategory_Path`,'-',id) as fullpath from chi_category order by fullpath asc,`DishCategory_Sort`asc
</code>

mysql order by语句,无限分类问题
fullpath是排序了,但是因为order by要求当按照多个列进行排序时,只有第一列相同时才使用第二列。但是第一组fullpath是不可能相同的。请问现在怎么实现比如 如图中红酒下级分类 红酒1和红酒2这两个再实现排序。
求教了

回复内容:

老师请帮忙看看?
无限分类里里面的同级分类如何实现再排序

<code>SELECT `DishCategory_Path`,`DishCategory_Name`,`DishCategory_Sort`,concat(`DishCategory_Path`,'-',id) as fullpath from chi_category order by fullpath asc,`DishCategory_Sort`asc
</code>

mysql order by语句,无限分类问题
fullpath是排序了,但是因为order by要求当按照多个列进行排序时,只有第一列相同时才使用第二列。但是第一组fullpath是不可能相同的。请问现在怎么实现比如 如图中红酒下级分类 红酒1和红酒2这两个再实现排序。
求教了

我仔细看了一下问题.

现在的第一个字段就是父级...
只需要一股脑的把所有分类全取出来,再用动态语言去排序即可。


旧答案:

再加一个字段 father,红酒1和红酒2的father都是0-12-16,即可。

<code>SELECT DishCategory_Path,DishCategory_Name,DishCategory_Sort,
      concat(DishCategory_Path,'-',id) as fullpath 
from chi_category 
order by concat(DishCategory_Path,'-',DishCategory_Sort)
</code>

这句话的效果

mysql order by语句,无限分类问题

其实我不知道这个问题最终是为了要解决什么问题,需求是什么没说清楚。
如果要在页面上按排序输出二级分类,那不是SQL做的事情。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.