news 2026/3/10 1:19:46

postgresql递归查询指定搜索顺序的方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
postgresql递归查询指定搜索顺序的方法

原文地址

搜索顺序

在使用递归查询进行树遍历计算时,你可能希望按照深度优先或广度优先的顺序对结果进行排序。这可以通过在数据列之外再计算一个排序列来实现,并在最后使用该列对结果进行排序。需要注意的是,这实际上并不会控制查询评估访问行的顺序;这个顺序在 SQL 中始终依赖于具体实现。此方法仅提供了一种在事后对结果进行排序的便捷方式。

创建深度优先顺序

我们可以为每个结果行计算一个数组,用于记录截至目前已访问过的行。例如,考虑以下使用link字段搜索表tree的查询:

WITHRECURSIVE search_tree(id,link,data)AS(SELECTt.id,t.link,t.dataFROMtree tUNIONALLSELECTt.id,t.link,t.dataFROMtree t,search_tree stWHEREt.id=st.link)SELECT*FROMsearch_tree;

要添加深度优先排序信息,可以这样写:

WITHRECURSIVE search_tree(id,link,data,path)AS(SELECTt.id,t.link,t.data,ARRAY[t.id]FROMtree tUNIONALLSELECTt.id,t.link,t.data,path||t.idFROMtree t,search_tree stWHEREt.id=st.link)SELECT*FROMsearch_treeORDERBYpath;

在一般情况下,如果需要使用多个字段来标识一行,可以使用行数组。例如,如果需要追踪字段f1f2

WITHRECURSIVE search_tree(id,link,data,path)AS(SELECTt.id,t.link,t.data,ARRAY[ROW(t.f1,t.f2)]FROMtree tUNIONALLSELECTt.id,t.link,t.data,path||ROW(t.f1,t.f2)FROMtree t,search_tree stWHEREt.id=st.link)SELECT*FROMsearch_treeORDERBYpath;

提示:在常见的只需追踪一个字段的情况下,可以省略ROW()语法。这样可以使用简单数组而非复合类型数组,从而提高效率。

创建广度优先顺序

你可以添加一个列来追踪搜索的深度,例如:

WITHRECURSIVE search_tree(id,link,data,depth)AS(SELECTt.id,t.link,t.data,0FROMtree tUNIONALLSELECTt.id,t.link,t.data,depth+1FROMtree t,search_tree stWHEREt.id=st.link)SELECT*FROMsearch_treeORDERBYdepth;

为了获得稳定的排序,可以将数据列作为次要排序列添加。

提示:递归查询评估算法会以广度优先搜索的顺序产生输出。然而,这是一个实现细节,依赖它可能并不可靠。每一层内的行顺序肯定是未定义的,因此在任何情况下,可能都需要一些显式的排序。

内置语法

PostgreSQL 提供了内置语法来计算深度优先或广度优先的排序列。例如:

WITHRECURSIVE search_tree(id,link,data)AS(SELECTt.id,t.link,t.dataFROMtree tUNIONALLSELECTt.id,t.link,t.dataFROMtree t,search_tree stWHEREt.id=st.link)SEARCH DEPTHFIRSTBYidSETordercolSELECT*FROMsearch_treeORDERBYordercol;
WITHRECURSIVE search_tree(id,link,data)AS(SELECTt.id,t.link,t.dataFROMtree tUNIONALLSELECTt.id,t.link,t.dataFROMtree t,search_tree stWHEREt.id=st.link)SEARCH BREADTHFIRSTBYidSETordercolSELECT*FROMsearch_treeORDERBYordercol;

该语法在内部会被扩展为类似于上述手写形式的内容。SEARCH子句指定了是需要深度优先还是广度优先搜索、用于排序的列列表,以及一个将包含可用于排序的结果数据的列名。该列将隐式添加到 CTE 的输出行中。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/4 13:47:03

基于大数据的国产跑鞋推荐与可视化分析系统(毕设源码+文档)

课题说明随着全民健身热潮兴起与国产运动品牌崛起,国产跑鞋市场规模持续扩大,但消费者普遍面临品类选择繁杂、适配需求匹配不精准、产品核心信息获取碎片化等问题,同时品牌方存在用户需求洞察不充分、产品优化缺乏数据支撑等痛点,…

作者头像 李华
网站建设 2026/3/5 6:26:12

美团战略携手赚转鱼科技 定义黄金回收“即时服务”新时代

——“上门即检、现场即付”创新模式借力超级平台,冲击传统行业格局深圳,2025年12月24日——近日,本地生活服务领域的领导者美团相关负责人与创新型科技企业深圳市赚转鱼科技有限公司业务部总监曾科文、人力总监覃丽莉、运营部负责人袁妙萍、…

作者头像 李华
网站建设 2026/3/4 3:07:42

香港科技大学突破性研究:让AI像指挥乐团一样看懂长视频

这项由香港科技大学刘润涛、刘子艺、唐嘉琦、马悦、皮仁杰、张季鹏和陈启峰等研究团队共同完成的研究于2025年12月发表在arXiv预印本平台上,论文编号为arXiv:2512.20618v1。有兴趣深入了解的读者可以通过该编号查询完整论文。当我们坐在电视机前观看一部两小时的电影…

作者头像 李华
网站建设 2026/3/5 20:18:52

13123123

1231231231

作者头像 李华