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中的递归查询.选择 *所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)