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