首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

父主键为主键的SQL同表查询中递归父/子

在SQL同表查询中,递归父/子是指通过父主键和子主键之间的关系,查询出某个节点的所有父节点或子节点。

概念: 递归父/子查询是一种在同一张表中查询父节点或子节点的方法。通过表中的主键和外键关系,可以建立起父子关系,从而实现递归查询。

分类: 递归父/子查询可以分为递归查询父节点和递归查询子节点两种情况。

优势: 递归父/子查询可以方便地查询出某个节点的所有父节点或子节点,无需额外的表或数据结构来存储关系。

应用场景: 递归父/子查询在许多场景中都有应用,例如组织架构中查询某个员工的所有上级领导、文件系统中查询某个文件的所有父目录等。

推荐的腾讯云相关产品: 腾讯云提供了一系列数据库产品和服务,可以满足不同场景下的需求。以下是一些推荐的腾讯云产品:

  1. 云数据库 TencentDB:腾讯云的云数据库产品,支持主流数据库引擎,提供高可用、高性能的数据库服务。可以通过SQL语句进行递归父/子查询。
  2. 云数据库 Redis:腾讯云的云数据库Redis版,是一种高性能的Key-Value存储系统。可以通过Redis的有序集合(Sorted Set)来实现递归父/子查询。
  3. 云数据库 CynosDB:腾讯云的云原生分布式数据库,基于开源的TiDB项目。可以通过SQL语句进行递归父/子查询。
  4. 云数据库 TcaplusDB:腾讯云的分布式NoSQL数据库,适用于海量数据存储和高并发读写场景。可以通过自定义的数据模型来实现递归父/子查询。

产品介绍链接地址:

  1. 云数据库 TencentDB:https://cloud.tencent.com/product/cdb
  2. 云数据库 Redis:https://cloud.tencent.com/product/redis
  3. 云数据库 CynosDB:https://cloud.tencent.com/product/cynosdb
  4. 云数据库 TcaplusDB:https://cloud.tencent.com/product/tcaplusdb

以上是关于SQL同表查询中递归父/子的完善且全面的答案,希望能对您有所帮助。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

(细节)My SQL主键0和主键自排约束关系

开始不设置主键 设计如下: 如果id位置有好几个0的话:设置主键并且自动排序时,0会从1开始递增; Insert 进去 id = 0数据,数据会从实际行数开始增加,和从0变化不一样; 现在主键是没有...使用limit查看指定范围数据时候这时候就会是从0开始往下排顺序,但是insert添加一行数据时候反而是跟行数有关系,这时候又是按照从1开始往下排顺序。...如果把某个主键数改成0,那直接就会进行排序放到正数前面,也就是说主键自排是允许有0存在,那为什么本身存在0要去修改成从1开始递增序列呢?...开始没0,增加主键自排约束,新添加主键是0行会根据行数自行变化,注意这里是新添加行,使用是insert。   开始没0,把某个主键数修改成0,这个0会直接在排好序了再在表里显示出来。...说得简单一点就是,增加主键自排约束后:    主键值:修改成0,可以存在,就是排个序。         新添加0,不允许存在,要根据行号改变。

1.2K40

(解释文)My SQL主键0和主键自排约束关系

上一篇我们说了关于自排如果主键是0问题,在这里我搞清楚了原因,导致这种情况是因为在SQL对自排设置了初始值:   从这里可以看到这两个变量一个是自增初始值,一个是增量,这里都是1,所以在设置自增时候会把那个字段原来存在所有...0变成从1开始步长1等差数列。   ...但是这个数值是可以被修改(不过在这里不建议修改),在insert时候如果插入是0,则会默认以插入行号为准,也就是默认值自动变成了行号。   ...首先我们得明白,主键自排,为什么要使用主键自排,还不因为以后索引等很多操作方便,所以这里插入时会以行号来改变0完全合理。

1.3K50
  • mysql编写sql脚本:要求没有主键,但是想查询没有相同值时候才进行插入

    @toc背景说明我这里主要针对2处地方要进行增量执行sql:1.新功能需要创建一张新结构indicator_alarm_threshold2.给菜单和另一个新增数据我们现在使用是项目启动先初始化加载...(没有主键,但是想查询没有相同值时候才进行插入)模板如果没有主键,你可以使用 WHERE NOT EXISTS 查询来在插入数据之前进行条件检查,确保没有相同值存在。...value1'、'value2' 是对应列值。在 WHERE NOT EXISTS 查询,我们检查表是否存在与要插入值匹配记录。如果不存在,就会执行插入操作。...请注意,FROM dual 是一个虚拟,在这里用于提供插入语句所需基础查询。你可以根据实际情况替换 'value1'、'value2' 和对应列名与值。...使用这种方法,只有当没有与要插入值匹配记录时,才会执行插入操作。否则,不会插入重复数据。

    6010

    Oracle 12.2 连接消除特性

    编辑手记:在12.1及以前版本,当祖父,,子表之间有明显主键和引用完整性约束,只有加入主键是单个列键时,才能进行连接消除; 但在12.2多列主键也允许发生连接消除,优化器从内联视图中删除对象...我当时使用SQL语句如下: ? 正如你接下来将看到三个,祖父,有明显主键和引用完整性约束。 这意味着祖父项具有单列主键项具有双列主键,子项具有三列主键。...查询沿着它们主键连接三个,然后仅从子表中选择数据,因此它是连接消除一个很好例子。...在早期版本Oracle连接,只有当加入主键是单个列键时,才能进行消除,因此12.1和更早版本将只能从此三连接消除祖父项; 但在12.2多列主键也允许发生连接消除,所以我们可能希望我们从这个查询获得计划将消除祖父母...然后优化器优化内联查询,消除祖父级在级和级之间留下联接,最后才允许级被删除。 但我们得到结果如下: ?

    1.5K60

    Google Cloud Spanner实践经验

    ,可以存储在关系()并进行查询,但它缺乏约束。...ON DELETE CASCADE 声明表示,当某一行被删除时,子表对应行也会被自动删除。如果没有该声明,或声明为ON DELETE NO ACTION,则必须先删除行,才能删除行。...交错行首先按行进行排序,然后在共享主键基础上,对子表进行再排序。...在对数据库进行分片操作时候,只要行以及子表行大小在8GB以内,并且在子表行没有热点,则每个以及子表数据存放区域关系会一保留下来。...二级索引(Secondary indexes) 在Cloud Spanner主键会被自动设置索引,Cloud Spanner也同时支持将其他非主键字段设置二级索引。

    1.4K10

    MySQL 索引原理 图文讲解

    索引 在数据库,索引可以理解是一种单独,物理对数据库一列或者多列值进行排序一种存储结构。...所以每次数据查询次数都一样。 非叶子节点节点数=关键字数。 遍历全节点数据只需要遍历所有叶子节点即可,这有利于数据库做全扫描。...通过非聚簇索引查询到了记录主键值,然后再根据主键值再到聚簇索引查找,就能查询到所有字段信息了,这就是回。 那SQL查询条件字段是非聚簇索引,是否就一定要进行回查询呢?...所以当在非聚簇索引查询结果满足不了返回字段时,才需要根据主键值到聚簇索引当中回查询需要字段。...所以我们在写SQL查询时候,如果能根据主键查询到我们想要数据,就优先使用主键查询;还有,在使用非聚簇索引查询数据时候,需要返回字段信息包括在非聚簇索引字段,就直接写返回字段,而不是写*号返回全部字段信息

    84820

    mysql递归查询方法|mysql递归查询遇到坑,教你们解决办法

    就一句sql就可以搞定,还有不清楚或者突然忘记需要温习小伙伴们,大家可以看小编发以前关于oracle递归查询方法,戳这里:【oracle递归查询方法介绍】 ---- 2.踩坑介绍 mysql递归查询...,就遇到了如开头所说一堆问题,所以大家在使用mysql递归方法之前一定要把这篇文章看完,因为你不看的话,等一下你一执行递归查询语句,一试一个错 3.埋坑教程 我就以这篇文章例了:https://blog.csdn.net...一定要注意里面的字段和你创建对应关系,这点也就是和oracle区别最大地方 看我下面的截图标记序号分别要注意要点, 1:你创建主键id, 2:你创建名, 3:你创建表示上级字段...②递归节点 那么接下来递归所有的节点,也是同样道理, 咱们先创建辅助函数getParList(), CREATE FUNCTION `getParList`(rootId INT) RETURNS...,我已经帮大家标记好了,将1到5数据,换成你创建主键名和表示上级字段,6可改可不改,你怎么高兴怎么来 ?

    1.4K20

    MySQL基础

    (与 NO ACTION 一致) CASCADE 当在删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表记录。...SET NULL 当在删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表该外键值 null(这就要求该外键允许取 null)。...SET DEFAULT 有变更时,子表将外键列设置成一个默认值(Innodb 不支持) # 多表查询 多表关系 一对多:在多一方设置外键,关联一一方主键 多对多:建立中间,中间包含两个外键...,关联两张主键 一对一:用于结构拆分,在其中任何一方设置外键(UNIQUE),关联另一方主键 多表查询 内连接 隐式: SELECT...FROM A,B WHERE 条件......查询:标量子查询、列子查询、行查询查询 # 事务 事务简介:事务是一组操作集合,这组操作,要么全部执行成功,要么全部执行失败。

    99830

    高级查询

    查询结果插入新 添加主键:ALTER TABLE 名 ADD CONSTRAINT 主键名 PRIMARY KEY 名(主键字段); 添加外键:ALTER TABLE 名 ADD CONSTRAINT...外键名FOREIGN KEY(外键字段)REFERENCES 关联名(关联字段); 查询语句中LIMIT子句 对查询结果进行限定、可指定查询起始位置和条数 查询多表数据 连接 查询 比较运算符...SELECT …… FROM 名 WHERE EXISTS(查询); 查询有返回行:返回TRUE 查询无返回行:返回FALSE 外层查询不执行 查询注意事项 查询语句可以嵌套在SQL语句中任何表达式出现位置...任何允许使用表达式地方都可以使用查询 嵌套在查询SELECT语句查询可包括 SELECT子句 FROM子句 WHERE子句 GROUP BY子句 HAVING子句 只出现在查询而没有出现在查询列不能包含在输出列...只出现在查询而没有出现在查询不能包含在输出列

    61320

    mysql省市区递归查询_mysql 递归查询

    递归查询节点 和节点 包含mysql 递归查询节点 和节点 mysql递归查询,查集合,查子集合 查子集合 –drop FUNCTION `getChildList` CREATE FUNCTION...在My … MySQL递归查询树状节点、节点具体实现 mysql版本(5.5.6等等)尚未支持循环递归查询,和sqlserver.oracle相比,mysql难于在树状中层层遍历节点.本程序重点参考了下面的资料...,写了两个sql存储过程,节点查询算 … 递归实际业务场景之MySQL 递归查询 喜欢就点个赞呗!...` varchar(32) DEFAUL … MySQL递归查询树状节点、节点 结构和数据就不公示了,查询user_role,主键是id,每条记录有parentid字段; 如下mysql...查询函数即可实现根据一个节点查询所有的节点,根据一个节点查询所有的节点.对于数据 … mysql 递归查询 主要是对于层级关系查询 最近遇到了一个问题,在mysql如何完成节点下所有节点或节点上所有节点查询

    10.8K20

    【MySQL】增删查改(进阶)

    此处起到约束作用班级,就叫做“”(parent),被约束这个,就叫做子表(child)。 外键约束,是对 子表做了约束,但与此同时。子表也在反过来约束了。...id1,被子表引用了,因此被约束,无法删除id1数据。 id2,没有被引用,可以删除。 这是为什么呢?每次给子表插入数据,势必要在查询一下这个id是否存在。...进行聚合,需要搭配聚合函数(SQL内置一组函数) 聚合函数 常见聚合函数有: 这些操作都是针对某个列所有行来进行运算。...同理,右连接,会把右结果尽量列出来,哪怕左没有对应李璐,就使用NULL来填充。 自连接 自连接就是自己和自己进行笛卡尔积。 查询 查询本质上就是套娃。...把多个SQL组合成一个。实际开发查询要慎用!

    3.1K20

    mysql在ubuntu操作笔记(详)

    )     - 特点:列值数,列值序   - 11.2 指定列插入值     - 语法:insert into table(col1,col2,col3) values(v1,v2,v3)     ...自关联   - 概念:让某张自己和自己进行连接。 26. 查询   - 概念:将一个查询结果在另一个查询中使用,称之为查询。   ...    - 相关子查询:       - 查询引用了查询结果或者查询引用了查询结果,查询查询都不可以独立运行   -26.2 查询注意点:     - 如果主查询使用到查询数据...,则必须给查询起一个名。     ...- 在查询使用关系运算符时候要注意,因为查询有可能返回多个值。

    1.1K40

    sql嵌套查询例子_sql多表数据嵌套查询

    大家好,又见面了,我是你们朋友全栈君。 查询学生上课人数超过 “Eastern Heretic” 任意一门课学生人数课程信息,请使用 ANY 操作符实现多行查询。...email varchar 讲师邮箱 age int 讲师年龄 country varchar 讲师国籍 本题涉及到多层嵌套: 第一层查询在课程 courses 查询满足条件全部课程信息...,这个条件由查询来完成,即为,查询学生上课人数超过 ”Eastern Heretic“ 任意一门课学生人数。...这一部分查询需要结合 ANY 操作符实现。之后,再将查询进行拆分,形成第二层嵌套子查询。...第二层查询在课程 courses 根据教师 id 查询学生上课人数, 其查询在教师表 teachers 查找教师名 name “Eastern Heretic” 教师 id。

    3.1K20

    SQL系列总结(三):DML(数据操纵语言)

    (学号:202103,课程号:1) INSERT INTO SC (Sno,Cno) VALUES('202103','1'); 2.插入查询结果 查询不仅可以嵌套在SELECT语句中来构造查询条件...其语句格式: INSERT INTO (, ···) [查询语句]; -- 可以理解在原来查询语句基础上将VALUE子句变为了查询语句 0x02.修改数据...1.普通修改 修改操作也称为更新操作,其语句一般格式: UPDATE SET =,=··· [WHERE ]; 其功能是修改指定满足WHERE...'李勇'; 如果省略WHERE子句,则修改对象所有元组 例:将所有的学生年龄增加一岁 UPDATE Student SET Sage=Sage+1 2.带有查询修改语句...如: 例:删除所有学生选课记录 DELETE FROM SC;-- 执行结果就是SC变成了一个空 2.带有查询删除语句 修改语句,查询也可以嵌套在DELETE语句中,用来构造执行删除操作条件

    32210

    我以为我对Mysql索引很了解,直到我被阿里面试官22连击

    而B+ 树是一种多路平衡查询树,所以他节点是天然有序(左节点小于节点、节点小于右节点),所以对于范围查询时候不需要做全扫描 Q:除了上面这个范围查询,你还能说出其他一些区别吗?...而非主键索引叶子节点是主键值,查到主键值以后,还需要再通过主键值再进行一次查询 Q:刚刚你提到主键索引查询只会查一次,而非主键索引需要回查询多次。...覆盖索引(covering index)指一个查询语句执行只用从索引中就能够取得,不必从数据读取。也可以称之为实现了索引覆盖。...当我们通过SQL语句:select key2 from covering_index_sample where key1 = 'keytest';时候,就可以通过覆盖索引查询,无需回。...、为什么你学不会递归

    1.1K10

    《MySQL之魅力无限:数据库世界瑰宝》

    结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询...SQL语法1,SQL语句可以在单行或多行书写,以分号结尾,有些时候可以不用分号结尾,比如在代码。2,可以使用空格或缩进来增强语句可读性3,SQL不区分大小写,建议大写。...默认值:default非空约束:not null唯一约束:unique主键约束:primary key外键约束:foreign key主键约束:非空+唯一用作这个主键所在字段是该唯一标识。...所以我们通常会指定主键类型整型,然后设置其自动增长,这样可以保证在插入数据时候主键唯一和非空特性。外键约束:保证数据完整性和有效性。...两张:主表主键子表:从外键演示外键约束子表设置外键列,是主键。那么子表中外键列,数值,就会受到主键数值约束。

    23110

    UbuntuMySQL数据库操作详解

    )     - 特点:列值数,列值序   - 11.2 指定列插入值     - 语法:insert into table(col1,col2,col3) values(v1,v2,v3)     ...自关联   - 概念:让某张自己和自己进行连接。 26. 查询   - 概念:将一个查询结果在另一个查询中使用,称之为查询。   ...    - 相关子查询:       - 查询引用了查询结果或者查询引用了查询结果,查询查询都不可以独立运行   -26.2 查询注意点:     - 如果主查询使用到查询数据...,则必须给查询起一个名。     ...- 在查询使用关系运算符时候要注意,因为查询有可能返回多个值。

    4.4K30

    推荐学Java——数据操作

    提示:你可以将sql理解一种编程语言格式,那么这其中用到所有标点符号都是英文,括号都是成对出现,这种低级错误千万别给自己养成"习惯"。...自然主键(推荐使用,主键尽量不要和业务数据挂钩) 业务主键(比如用学号做主键,一单业务有变化,主键相关可能就会有问题) 外键约束:foreign key 一张某个字段在另外一张中被标记为外键约束...被标记字段称为子表,另外一张 删除数据,先删除子表,再删除 插入数据,先插入,再插入子表 语法格式: ```sql foreign key(列名) references 表表名(要被添加列名...); ``` 外键(列)不一定要是主键,但至少具有 unique 约束;外键可以为Null ....=不是标准 SQL 语法,才是标准不等于。 sql查询某个null值,要使用 is null ,而不是= null ;相反,要查询不为null,那么使用is not null .

    2.6K20

    Entity Framework 继承映射

    某些属性对于子类来说并不是必需,因此Code First 会将改属性创建可空列。TPH策略因为有 discriminator 列存在,维护性不强,因此违反了第三范式。...一、TPT TPT是常用策略,通过外键来表示继承,类和子类分别位于不同,子类包含自身属性列和外键,并将外键作为子类主键。...与多态关联将被表示引用外键。缺点在于性能极差,如果要进行查询就要多表连接查询。...二、 TPC TPC是不被推荐策略,因为他会为每个子类创建一个,并且将所有属性映射进每个子类。...,因此插入到子类数据会存在重复主键

    80110
    领券