SQL中的CTE有什么用
小编给大家分享一下SQL中的CTE有什么用,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!
CTE表示公用表表达式,是一个临时命名结果集,始终返回结果集。它是为了简化SQL查询,而被标准SQL引入的。下面本篇文章就来带大家认识一下CTE(公用表表达式),希望对大家有所帮助。
CTE是什么?
公用表表达式(CTE)可以被认为是在单个SELECT,INSERT,UPDATE,DELETE或CREATE VIEW语句的执行范围内定义的临时结果集。CTE类似于派生表,因为它不作为对象存储,并且仅在查询期间持续。与派生表不同,CTE可以是自引用的,并且可以在同一查询中多次引用。【相关视频教程推荐:MySQL教程】
CTE的结构
CTE由表示CTE的表达式名称,AS关键字和SELECT语句组成。定义CTE后,可以在SELECT,INSERT,UPDATE或DELETE语句中像表或视图一样引用它。CTE也可以在CREATE VIEW语句中用作其定义SELECT语句的一部分。
CTE的基本语法结构是:
WITH Expression_Name [ ( ColumnName [1,...n] ) ]
AS
( CTE query definition )
说明:我们可以通过在SELECT,INSERT,UPDATE,DELETE或MERGE语句之前直接添加WITH子句来定义CTE。WITH子句中可以包含一个或多个逗号分隔的CTE。
运行CTE的声明是:
SELECT <column_list>
FROM expression_name;
CTE的类型
CTE有两种类型:递归和非递归。
递归CTE:是引用自身的常用表表达式。
非递归CTE,顾名思义,不使用递归;他们不参考自己。
使用CTE的好处
○ 可读性:CTE提高了可读性。而不是将所有查询逻辑都集中到一个大型查询中,而是创建几个CTE,它们将在语句的后面组合。这使您可以获得所需的数据块,并将它们组合在最终的SELECT中。
○ 替代视图:您可以用CTE替换视图。如果您没有创建视图对象的权限,或者您不想创建一个视图对象,因为它仅在此一个查询中使用,这很方便。
○ 递归:使用CTE会创建递归查询,即可以调用自身的查询。当您需要处理组织结构图等分层数据时,这很方便。
○ 限制:克服SELECT语句限制,例如引用自身(递归)或使用非确定性函数执行GROUP BY。
○ 排名:每当你想使用排名函数,如ROW_NUMBER(),RANK(),NTILE()等。
看完了这篇文章,相信你对SQL中的CTE有什么用有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341