递归sql的功率到达MySQL和MariaDB

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

递归式sql是当今许多现代数据库中最吸引人、最强大、最危险的特性之一,它使用了第一99标准中首次引入的共同表达式(CTE)。中的的第一个实现开始出现在2006-7中,在MySQL 8.0和MariaDB版本10.2.2中出现。


公共表表达式(带递归子句…子句)

递归式sql是通过使用共同或CTE实现的,它是一个临时命名的resultset,它是从一个简单的查询派生出来的,并在选择、插入、更新或删除语句的执行范围内定义。CTE通常用于简化和(或)将代码转换为可读性更强的部分,从而提高了sql代码的可读性。中的的一个“特性”是能够递归引用命名的resultset,从而递归地引用。


通过递归的sql查询,您可以实现您不可能想象到的在这种类型的sql和它执行的速度上是可能的事情。您可以解决许多类型的业务问题,甚至重写一些复杂的sql/应用程序逻辑,直到对数据库进行简单的recursiveSQL调用。

递归CTE的一些有用的用法示例是,您可以使用它来查找数据中的空白,创建组织结构图并创建测试数据。

我最喜欢的使用递归式sql查询的方法是,根据数据的复杂性和可用的数据库/系统资源,生成大量的测试数据。使用递归CTE,我们可以在非常短的时间内产生数百、数千或数百万条记录,然后只限于可用的数据库内存和其他数据库/系统资源。与我所见和经历的其他测试数据过程相比,递归查询产生的测试数据更快。
此外,已经证明递归查询比其他需要几天的查询在数分钟内执行的查询要好。


递归这个词说的都是。您有一个查询,该查询会反复调用自己的某个起始点,即极其重要a.a终点(A)安全出口就像我说的那样。如果你没有一个安全的退出,或者你的递归公式超出它,你就陷入了深深的麻烦。您的查询将进入无限环导致非常高的cpu和非常高的日志利用率,这将导致内存和/或存储耗尽。如果你的查询失控,你必须快速思考并停止它。如果您不能这样做,那么立即通知您的DBA,这样他/她就可以通过杀死runnaway线程来阻止数据库系统的阻塞。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
23天前
|
SQL 关系型数据库 MySQL
mysql一条sql查询出多个统计结果
mysql一条sql查询出多个统计结果
14 0
|
1天前
|
SQL 关系型数据库 MySQL
:“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi
:“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi
6 0
|
9天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
36 3
|
16天前
|
SQL 存储 关系型数据库
【MySQL实战笔记】02.一条SQL更新语句是如何执行的-2
【4月更文挑战第5天】两阶段提交是为确保`redo log`和`binlog`逻辑一致,避免数据不一致。若先写`redo log`, crash后数据可能丢失,导致恢复后状态错误;若先写`binlog`,crash则可能导致重复事务,影响数据库一致性。一天一备相较于一周一备,能缩短“最长恢复时间”,但需权衡额外的存储成本。
16 1
|
23天前
|
SQL 关系型数据库 MySQL
【MySQL】慢SQL分析流程
【4月更文挑战第1天】【MySQL】慢SQL分析流程
|
26天前
|
SQL 关系型数据库 MySQL
【MySQL技术之旅】(7)总结和盘点优化方案系列之常用SQL的优化
【MySQL技术之旅】(7)总结和盘点优化方案系列之常用SQL的优化
39 1
|
4月前
|
SQL 存储 关系型数据库
MySQL下使用SQL命令进行表结构与数据复制实践
MySQL下使用SQL命令进行表结构与数据复制实践
62 0
|
9月前
|
SQL 关系型数据库 MySQL
MySQl数据库第八课-------SQL命令查询-------主要命脉2
MySQl数据库第八课-------SQL命令查询-------主要命脉
|
9月前
|
SQL 关系型数据库 MySQL
MySQl数据库第八课-------SQL命令查询-------主要命脉 1
MySQl数据库第八课-------SQL命令查询-------主要命脉
|
9月前
|
SQL 存储 开发框架
MySQl数据库第六课-------SQl命令的延续------快来看看
MySQl数据库第六课-------SQl命令的延续------快来看看