微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLite 中的递归

create table if not exists testTable( id INT PRIMARY KEY,[name] NVARCHAR(20),parentId INT );
INSERT INTO testTable(id,[name],parentId) VALUES(1,'xf1',0);
INSERT INTO testTable(id,parentId) VALUES(2,'xf2',parentId) VALUES(3,'xf3',2);
INSERT INTO testTable(id,parentId) VALUES(4,'xf4',3);
INSERT INTO testTable(id,parentId) VALUES(5,'xf5',4);
INSERT INTO testTable(id,parentId) VALUES(6,'xf6',5);

WITH RECURSIVE 
  cte(id,name,parentId) AS(
    SELECT id,parentId FROM testTable WHERE id='6'
    UNION ALL
    SELECT a.id,a.name,a.parentId FROM testTable AS a INNER JOIN 
        cte ON a.id=cte.parentId   
)
SELECT * FROM cte;



--得到1-10 的数
WITH RECURSIVE
  cnt(x) AS (VALUES(1) UNION ALL SELECT x+1 FROM cnt WHERE x<10)
SELECT x FROM cnt order by x;

WITH RECURSIVE
  cnt(x) AS (
     SELECT 1
     UNION ALL
     SELECT x+1 FROM cnt
      LIMIT 10
  )
SELECT x FROM cnt order by x;


参考:点击打开链接

原文地址:https://www.jb51.cc/sqlite/198220.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐