加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite 中的递归

发布时间:2020-12-12 19:18:29 所属栏目:百科 来源:网络整理
导读: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 IN
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;


参考:点击打开链接

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读