1、开发中我们经常会遇到数据库中的数据存在存在上小级的父子关系,如全国的省市信息,或者一个公司的部门信息等。
如果我们在查询的时候使用递归的方法直接将数据查询出来就可以避免我们在程序中在进行递归过滤数据了,下面我们以全国的省市为例,首先我们定义一张表,表的定义如下:
然后我们在其中放一些数据,数据如下:
递归有向上递归与向下递归,首先我们向下递归,查询河南省下面的所有记录,查询语句如下:
WITH RECURSIVE temptable AS (
SELECT * FROM t_provinces WHERE pid = 2
union ALL
SELECT t_provinces.* FROM t_provinces, temptable WHERE t_provinces.parentid = temptable.pid
)
SELECT * FROM temptable ORDER BY pid;
查询结果如图:
这样就将河南省下面的所有记录全部查了出来。
然后我们向上递归,查询栾川县的所有父记录。查询语句如下:
WITH RECURSIVE temptable AS (
SELECT * FROM t_provinces WHERE pid = 28
union ALL
SELECT t_provinces.* FROM t_provinces, temptable WHERE t_provinces.pid = temptable.parentid
)
SELECT * FROM temptable ORDER BY pid;
查询结果图如下:
这样就查询出来了栾川县的所有父记录。