KingbaseES的SQL语句-CTE递归
背景
从上下级关系表中,任意一个节点数据出发,可以获得该节点的上级或下级。CTE的递归语法,或者 connect by 与 start with的 查询语法,能够实现这个需求。
当我们需要制作上下级关系的数据时,也可以使用CTE的递归语法。
举例
一个父节点拥有随机数量的子节点,通过控制层级数和随机数的上限,可以实现海量的数据集合。
drop table t_level1;
create table t_level1
(
id int primary key,
pid int
);
create index t_level1_pid on t_level1 (pid);
--Sequence For Primary key
create sequence seq_level1;
select count(*) from t_level1;
truncate t_level1;
--方法一:使用表作为record type,生成record数组
with recursive rec as (
--Root Node
select array_agg((id, pid)::t_level3) as recs,
5 as max_lvl, --最大level
5 as rec_cnt --最大子节点数
from (select nextval('seq_level1') as id, null as pid) t
union all
--Children Node, Random Number
select array_agg((id, pid)::t_level3) as recs,
recp.max_lvl as max_lvl,
rec_cnt as rec_cnt
from (select (unnest(rec.recs)).id as pid,
rec.max_lvl - 1 as max_lvl,
rec_cnt as rec_cnt
from rec
where rec.max_lvl > 1) as recp
, lateral (select nextval('seq_level1') as id
from generate_series(1, (random() * rec_cnt)::int)
where pid > 0) t2
group by pid, max_lvl, rec_cnt
)
select (unnest(recs)).*
from rec;
--方法二:使用主键作为type,生成主键类型数组
with recursive rec as (
--Root Node
select array_agg(nextval('seq_level1')) as ids,
null::bigint as pid,
5 as max_lvl, --最大level
5 as rec_cnt --最大子节点数
union all
--Children Node, Random Number
select (select array_agg(nextval('seq_level1')) as ids
from generate_series(1, (random() * rec_cnt)::int)
) as ids,
pid as pid,
max_lvl as max_lvl,
rec_cnt as rec_cnt
from (select unnest(rec.ids) as pid,
rec.max_lvl - 1 as max_lvl,
rec_cnt as rec_cnt
from rec
where rec.max_lvl > 1) as recp
)
select unnest(ids) as id, pid, max_lvl
from rec;
KingbaseES的SQL语句-CTE递归的更多相关文章
- SQL笔记 - CTE递归实例:显示部门全称
昨天在整理JS的Function时,示例是一个递归函数.说起递归,想起前段时间在搞CTE,那个纠结呀,看似容易,可我总抓不住门道,什么递归条件,什么结束条件,一头雾水...今天一大早就爬起来,果然不负 ...
- Sql Server CTE递归
WITH cte AS ( SELECT a.FNUMBER,a.FMATERIALID AS MainId,b.FMATERIALID AS ChileID,CAST(b.FMATERIALID A ...
- sql server CTE递归使用测试
--CTE递归查询 if(object_id(N'menu') > 0) drop table menu CREATE TABLE MENU ( name nvarchar(50) NOT NU ...
- SQL笔记 - CTE递归实例(续):显示指定部门的全称
前一篇文章中已经可以取得所有部门的全称,但现在又有个新的需求: 只想得到某一个部门的部门全称,虽然可以用where条件来过滤,但是会有点小浪费. 这时我们可以从后往前找,先看下效果: 最后一条就是,行 ...
- SQL With(递归 CTE 查询)
本文来自:http://www.cnblogs.com/smailxiaobai/archive/2012/01/16/2323291.html 指定临时命名的结果集,这些结果集称为公用表表达式 (C ...
- SQL 递归查询,意淫CTE递归的执行步骤
今天用到了sql的递归查询.递归查询是CTE语句with xx as(....)实现的. 假如表Category数据如下. 我们想查找机枪这个子分类极其层次关系(通过子节点,查询所有层级节点).以下是 ...
- SQL Server中公用表表达式 CTE 递归的生成帮助数据,以及递归的典型应用
本文出处:http://www.cnblogs.com/wy123/p/5960825.html 我们在做开发的时候,有时候会需要一些帮助数据,必须需要连续的数字,连续间隔的时间点,连续的季度日期等等 ...
- 求SQL语句递归的算法
表结构是这样的 部门 上级部门 A BB CC DA AB BC C ...
- TSql CTE 递归原理探究
CTE是如何进行递归的?产生递归的条件有三个,分别是 初始值 自身调用自身 结束递归的条件 1,示例代码 ;with cte as ( as jd union all as jd from cte ) ...
随机推荐
- node开启 https线上服务你不会吗?
var https=require("https");//https服务var fs = require("fs")var express = require( ...
- C#判断数组或集合中是否含有属性值为value的对象
/// <summary> /// 判断list中是否有某个对象的Id_srvplan为value /// </summary> /// <param name=&quo ...
- ansible-playbook批量修改密码
1. 将服务器ip写到ansible hosts文件中 2. 实现免密登录服务器 将ansible服务器公钥拷贝到目标服务器用户目录下的.ssh/authorized_keys 手动连接一次或者自己写 ...
- 由ASP.NET Core根据路径下载文件异常引发的探究
前言 最近在开发新的项目,使用的是ASP.NET Core6.0版本的框架.由于项目中存在文件下载功能,没有使用类似MinIO或OSS之类的分布式文件系统,而是下载本地文件,也就是根据本地文件路径进行 ...
- sql server 跨IP库更新表字段(OPENDATASOURCE 、update)
--跨ip库更新表字段 update uat set goodsType=dev.goodsType from OPENDATASOURCE('SQLOLEDB','Data Source=127.0 ...
- 还在因为部署 Kubernetes 时,无法拉取 k8s.gcr.io/*** 镜像而头疼吗
拉取外网 Kubernetes 镜像 还在因为部署 Kubernetes 时,无法拉取 k8s.gcr.io/*** 镜像而头疼吗? 传送门 https://github.com/liamhao/pu ...
- XJSON 是如何实现四则运算的?
前言 在上一篇中介绍了 xjson 的功能特性以及使用查询语法快速方便的获取 JSON 中的值. 同时这次也更新了一个版本,主要是两个升级: 对转义字符的支持. 性能优化,大约提升了30%️. 转义字 ...
- java中AOP的环绕通知
pom.xml <dependencies> <dependency> <groupId>org.springframework</groupId> & ...
- 算法竞赛进阶指南0x14 Hash
组成部分: 哈希函数: 链表 AcWing137. 雪花雪花雪花 因为所需要数据量过于大,所以只能以O(n)的复杂度. 所以不可能在实现的过程中一一顺时针逆时针进行比较,所以采用一种合适的数据结构. ...
- C#程序设计的6大原则
设计模式:面向对象语言开发过程中,遇到各种场景和问题,解决方案和思路沉淀下来,就是设计模式.俗称,套路 设计模式的六大原则:理解为面向对象语言开发过程中推荐的一些指导性的原则,通俗的说是套路的 套路 ...