最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql爷儿俩结构排序

来源:懂视网 责编:小采 时间:2020-11-09 13:33:35
文档

mysql爷儿俩结构排序

mysql爷儿俩结构排序:mysql 父子结构排序 项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如SqlServer中用with union 实现,而Mysql则没有这么方便的语句。 如下category表,食品有pizaa,buger,coffee,而pizza又分了加cheese几种,如何
推荐度:
导读mysql爷儿俩结构排序:mysql 父子结构排序 项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如SqlServer中用with union 实现,而Mysql则没有这么方便的语句。 如下category表,食品有pizaa,buger,coffee,而pizza又分了加cheese几种,如何

mysql 父子结构排序 项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如SqlServer中用with union 实现,而Mysql则没有这么方便的语句。 如下category表,食品有pizaa,buger,coffee,而pizza又分了加cheese几种,如何将他们的父子结构

mysql 父子结构排序

项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如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) DETERMINISTIC
begin
 DECLARE 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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

mysql爷儿俩结构排序

mysql爷儿俩结构排序:mysql 父子结构排序 项目中经常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比如SqlServer中用with union 实现,而Mysql则没有这么方便的语句。 如下category表,食品有pizaa,buger,coffee,而pizza又分了加cheese几种,如何
推荐度:
标签: 排序 mysql 结构
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top