postgresql有很多比较妖的数据类型,ltree算一个。
简介
ltree是Postgresql的一个扩展类型 http://www.sai.msu.su/~megera...,在解决树形结构的数据存储上使用。
查看是否安装了插件
1
|
select * from pg_extension where extname = 'ltree' ;
|
定义
字段的格式为:L1.L2.L3.L4.L5.L6.....
标签是一系列字母数字字符和下划线A-Za-z0-9_, 标签长度必须小于256个字节。标签路径是由点分隔的零个或多个标签的序列,例如L1.L2.L3,表示从分层树的根到特定节点的路径。 标签路径的长度必须小于65Kb,但最好保持在2Kb以下。
查询
创建临时表:
1
|
create table tmp.ltree_table( name varchar , path ltree);
|
写入测试数据
1
2
3
4
5
6
7
|
insert into tmp.ltree_table values ( '小明' , '北京.东城.小明' );
insert into tmp.ltree_table values ( '小刚' , '北京.西城.小刚' );
insert into tmp.ltree_table values ( '小红' , '北京.南城.小红' );
insert into tmp.ltree_table values ( '小小明' , '北京.东城.小明.小小明' );
insert into tmp.ltree_table values ( '小明明' , '北京.东城.小明.小明明' );
insert into tmp.ltree_table values ( '小小红' , '北京.东城.小红.小小红' );
insert into tmp.ltree_table values ( '小红红' , '北京.东城.小红.小红红' );
|
查询写入的数据
小明 | 北京.东城.小明
小刚 | 北京.西城.小刚
小红 | 北京.南城.小红
小小明 | 北京.东城.小明.小小明
小明明 | 北京.东城.小明.小明明
小小红 | 北京.南城.小红.小小红
小红红 | 北京.南城.小红.小红红
结构树如下:
查询所有的人和他的孩子的对应关系:
1
|
select c. name , s. name from tmp.ltree_table s join ( select path , name from tmp.ltree_table ) c on s.path <@ c.path and s. name <> c. name ;
|
小明 | 小小明
小明 | 小明明
小红 | 小小红
小红 | 小红红
查询覆盖的所有的区域:
1
|
select subltree(path,1,2) from tmp.ltree_table;
|
东城
西城
南城
东城
东城
南城
南城
查询所有南城的人:
1
|
select distinct s. name from tmp.ltree_table s where subltree(s.path,1,2) = '南城' ;
|
小小红
小红红
小红
查询路径长度:
1
|
select s. name ,nlevel(s.path) from tmp.ltree_table s;
|
小明 | 3
小刚 | 3
小红 | 3
小小明 | 4
小明明 | 4
小小红 | 4
小红红 | 4
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。
原文链接:https://segmentfault.com/a/1190000020300647