• 优化sql嵌套查询,使用CTE语法


    CTE语法(子查询部分),目的是为了提高可读性和可维护性。把子查询部分提出来之后再使用。

    eg:

    with

    cr as(select * form  A where...)

    select * form B where B.a in (select cr.a from cr)

    使用CTE注意事项:

    1,CTE后面必须直接跟着查询语句(select,update,insert),否则,CTE将失效。

    2,CTE后面也可以跟其他CTE语句,但是只能使用一个with,多个CTE语句之间需要用逗号(,)分隔。

    3,如果CTE的表达式名称与某个数据表或者视图重名,则紧跟在该CTE后面的SQL语句使用的仍然是CTE,当然,后面的SQL语句使用的就是数据表或视图了,例如:

    with
    A as ( select * from B where age < 30 ) 
    select * from A-- 使用了名为A的公共表表达式 
    select * from A-- 使用了名为A的数据表

    4,CTE 可以引用自身,也可以引用在同一 WITH 子句中预先定义的 CTE。不允许向前引用。

    (理解)就是在as之后的的括号中引用他自己的cte名称,不能引用下一句cte名称。

    5. 不能在 CTE_query_definition 中使用以下子句:

    (1)COMPUTE 或 COMPUTE BY

      (2)ORDER BY(除非指定了 TOP 子句)

      (3)INTO

      (4)带有查询提示的 OPTION 子句

      (5)FOR XML

      (6)FOR BROWSE

    6,如果将 CTE 用在属于批处理的一部分的语句中,那么在它之前的语句必须以分号结尾

    declare @a nvarchar(3) 
    set @a = 'C%' ; -- 必须加分号 
    with
     t_tree as ( select A.name from A where name like @a ) 
    select * from B where B.name in (select * from t_tree)
  • 相关阅读:
    MySQL 数据实时同步到 Elasticsearch 的技术方案选型和思考
    编写高质量可维护的代码之优化逻辑判断
    Java8 lambda表达式常见用法
    jar安装到maven本地仓库
    微信小程序获取用户手机号
    spring aop 、Redis实现拦截重复操作
    redis自定义RedisCacheManager
    locust做并发测试实战
    几个绕过短信验证码限制的漏洞挖掘
    通达OA任意用户登录和后台GetShell漏洞复现
  • 原文地址:https://www.cnblogs.com/zhangrgLearning/p/13256428.html
Copyright © 2020-2023  润新知