PostgreSQL之树形展示

开心一笑

一位男士对朋友说:“昨天我和老婆打完架之后,老婆跪在我的面前。”
朋友惊讶地说:“哎呀!你真了不起。不过,你老婆跪着时对你说什么?”
男士答道:“她说‘你这个死东西,快点给我从床底下滚出来’。”

视频教程

大家好,我录制的视频《Java之优雅编程之道》已经在CSDN学院发布了,有兴趣的同学可以购买观看,相信大家一定会收获到很多知识的。谢谢大家的支持……

视频地址:http://edu.csdn.net/lecturer/994

视频教程

大家好,我录制的视频《Java之优雅编程之道》已经在CSDN学院发布了,有兴趣的同学可以购买观看,相信大家一定会收获到很多知识的。谢谢大家的支持……

视频地址:http://edu.csdn.net/lecturer/994

提出问题

PostgreSQL如何把数据展示成树形结构???

解决问题

with的具体语法,可以看看我的这篇文章:
http://blog.csdn.net/huangwenyi1010/article/details/51220341

建表:


create table ay_tree_test(id varchar(3) , pid varchar(3) , name varchar(10)); 

插入数据:

INSERT INTO ay_tree_test values('001','0','厦门市');
INSERT INTO ay_tree_test values('002','001','海沧区','2100');
INSERT INTO ay_tree_test values('003','001','集美区','2500');
INSERT INTO ay_tree_test values('004','001','同安区','1500');
INSERT INTO ay_tree_test values('005','002','区政府','1');
INSERT INTO ay_tree_test values('006','002','青春海岸','10');
INSERT INTO ay_tree_test values('007','002','未来海岸','15');

例一:1+2+….100 用RECURSIVE实现递归

 WITH RECURSIVE t(n) AS (
    VALUES (1)
  UNION ALL
    SELECT n+1 FROM t 
    WHERE n < 100
)
SELECT sum(n) FROM t;

解释:RECURSIVE 是递归的意思,可以把VALUES (1)当中初始条件,即n = 1时:
1 union all select 2 from t
n = 2时:
1 union all select 2 from t union all select 3 from t
……
……

当n>100 时跳出循环,及where n >100时,跳出循环,这是我个人的理解方法,你可以有自己更好的理解方法.

例二:

with recursive cte as 
 ( 
 select a.id,a.name,a.pid from ay_tree_test a where id='001' 
 union all  
 select k.id,k.name,k.pid  from ay_tree_test k inner join cte c on c.id = k.pid 
 )select id,name,pid from cte;

结果如下,利用上面的理解方法,树形结构就展示出来了:

这里写图片描述

读书感悟

  • “越早行动越好”是至理名言。遇不到对的人,恋爱失败,这些都是正常的,想想概率问题吧。失败10次才能成功1次,那就千万不要在失败了5次的时候就停止脚步。
  • 《编辑部的故事》里那句脍炙人口的名言: 金钱不是万能的,但没有钱是万万不能的。
  • 你为什么要有钱,真正的原因,是追求你的梦想,实现你的人生价值。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿_毅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值