博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
递归sql的功率到达MySQL和MariaDB
阅读量:6149 次
发布时间:2019-06-21

本文共 846 字,大约阅读时间需要 2 分钟。

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

转载地址:http://rxqya.baihongyu.com/

你可能感兴趣的文章
List Collections sort
查看>>
Mysql -- You can't specify target table 'address' for update in FROM clause
查看>>
使用局部标准差实现图像的局部对比度增强算法。
查看>>
2017-2018-1 20165313 《信息安全系统设计基础》第八周学习总结
查看>>
《代码敲不队》第四次作业:项目需求调研与分析
查看>>
菜鸡互啄队—— 团队合作
查看>>
HttpWebRequest的GetResponse或GetRequestStream偶尔超时 + 总结各种超时死掉的可能和相应的解决办法...
查看>>
SparseArray
查看>>
第二章
查看>>
android背景选择器selector用法汇总
查看>>
[转]Paul Adams:为社交设计
查看>>
showdialog弹出窗口刷新问题
查看>>
java
查看>>
Vue.js连接后台数据jsp页面  ̄▽ ̄
查看>>
关于程序的单元测试
查看>>
mysql内存优化
查看>>
都市求生日记第一篇
查看>>
Java集合---HashMap源码剖析
查看>>
SQL优化技巧
查看>>
thead 固定,tbody 超出滚动(附带改变滚动条样式)
查看>>