> 데이터 베이스 > MySQL 튜토리얼 > mysql 父子结构排序_MySQL

mysql 父子结构排序_MySQL

WBOY
풀어 주다: 2016-06-01 13:15:55
원래의
1020명이 탐색했습니다.

项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如SqlServer中用with union 实现,而Mysql则没有这么方便的语句。

如下category表,食品有pizaa,buger,coffee,而pizza又分了加cheese几种,如何将他们的父子结构表现出来呢?

CREATE TABLE category(	id INT(10),	parent_id INT(10),	name VARCHAR(50));INSERT INTO category (id, parent_id, name) VALUES(1, 0, 'pizza'),		--node 1(2, 0, 'burger'),	 --node 2(3, 0, 'coffee'),	 --node 3(4, 1, 'piperoni'),	 --node 1.1(5, 1, 'cheese'),	 --node 1.2(6, 1, 'vegetariana'),--node 1.3(7, 5, 'extra cheese'); --node 1.2.1
로그인 후 복사

stackoverflow上一个人给了一个很好的解决方案:

1. 创建一个函数

delimiter ~DROP FUNCTION getPriority~CREATE FUNCTION getPriority (inID INT) RETURNS VARCHAR(255) DETERMINISTICbeginDECLARE gParentID INT DEFAULT 0;DECLARE gPriority VARCHAR(255) DEFAULT '';SET gPriority = inID;SELECT parent_id INTO gParentID FROM category WHERE ID = inID;WHILE gParentID > 0 DO/*0为根*/SET gPriority = CONCAT(gParentID, '.', gPriority);SELECT parent_id INTO gParentID FROM category WHERE ID = gParentID;END WHILE;RETURN gPriority;end~delimiter ;
로그인 후 복사
2. 调用函数得到的便是排完序的结果
SELECT * FROM category ORDER BY getPriority(ID);
로그인 후 복사

☆ getPriority 这个函数的限制条件是:所有数据追溯上去必须有唯一的祖先。从树结构来看,不能有多棵树。

来源:http://stackoverflow.com/questions/14890204/order-sql-tree-hierarchy

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿