PostgreSQL中的递归查询.选择 *

PostgreSQL中的递归查询.选择 *,第1张

概述我有递归查询来检索给定人的所有孩子 WITH RECURSIVE recursetree(id, parent_id) AS ( SELECT id, parent_id FROM tree WHERE parent_id = 0 UNION SELECT t.id, t.parent_id FROM tree t JOIN recursetree rt ON 我有递归查询来检索给定人的所有孩子

WITH RECURSIVE recursetree(ID,parent_ID) AS (    SELECT ID,parent_ID FROM tree WHERE parent_ID = 0  UNION    SELECT t.ID,t.parent_ID    FROM tree t    JOIN recursetree rt ON rt.ID = t.parent_ID  )SELECT * FROM recursetree;

如您所见,我正在指定要检索的列的列表.但是我想使用SELECT *(我在真正的表中有很多列,将来可以更改它们).有没有办法获得所有列而不单独定义每列?

解决方法 您无需在WITH部分中指定列.如果省略,列名将由UNION中的第一个查询确定:

WITH RECURSIVE recursetree AS (    SELECT * FROM tree WHERE parent_ID = 0  UNION    SELECT t.*    FROM tree t    JOIN recursetree rt ON rt.ID = t.parent_ID)SELECT * FROM recursetree;
总结

以上是内存溢出为你收集整理的PostgreSQL中的递归查询.选择 *全部内容,希望文章能够帮你解决PostgreSQL中的递归查询.选择 *所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1160502.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存