递归sql的功率到达MySQL和MariaDB

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

递归式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线程来阻止数据库系统的阻塞。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
12天前
|
SQL 运维 关系型数据库
MySQL 运维 SQL 备忘
MySQL 运维 SQL 备忘录
38 1
|
1天前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
6 0
|
1天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
6 0
|
14天前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
30 0
|
14天前
|
SQL 存储 关系型数据库
mysql SQL必知语法
本文详细介绍了MySQLSQL的基本语法,包括SELECT、FROM、WHERE、GROUPBY、HAVING、ORDERBY等关键字的使用,以及数据库操作如创建、删除表,数据类型,插入、查询、过滤、排序、连接和汇总数据的方法。通过学习这些内容,读者将能更好地管理和操
9 0
|
NoSQL 关系型数据库 MySQL
阿里云RDS关系型数据库大全_MySQL版、PolarDB、PostgreSQL、SQL Server和MariaDB等
阿里云RDS关系型数据库如MySQL版、PolarDB、PostgreSQL、SQL Server和MariaDB等,NoSQL数据库如Redis、Tair、Lindorm和MongoDB
326 0
|
3月前
|
关系型数据库 Java MySQL
Linux安装JDK1.8 & tomcat & MariaDB(MySQL删减版)
本教程提供了在Linux环境下安装JDK1.8、Tomcat和MariaDB的详细步骤。这三个组件的组合为Java Web开发和部署提供了一个强大的基础。通过遵循这些简单的指导步骤,您可以轻松建立起一个稳定、高效的开发和部署环境。希望这个指导对您的开发工作有所帮助。
182 8
|
4月前
|
缓存 关系型数据库 MySQL
error: Failed dependencies: mariadb-connector-c-config is obsoleted by mysql-community-server-8.0.36-1.el7.x86_64 问题解决
error: Failed dependencies: mariadb-connector-c-config is obsoleted by mysql-community-server-8.0.36-1.el7.x86_64 问题解决
192 19
|
3月前
|
SQL 关系型数据库 MySQL
如何在 MySQL 或 MariaDB 中导入和导出数据库
如何在 MySQL 或 MariaDB 中导入和导出数据库
414 0
|
3月前
|
SQL Ubuntu 关系型数据库
如何在云服务器上创建和管理 MySQL 和 MariaDB 数据库
如何在云服务器上创建和管理 MySQL 和 MariaDB 数据库
42 0

推荐镜像

更多