前言
本文将为开发者系统解析mysql 8.0引入的cte特性。通过真实业务场景案例,您将掌握:
- 如何用cte重构嵌套噩梦般的sql语句
- 递归查询实现树形结构遍历的核心方法
- 通过查询复用提升30%以上执行效率的技巧
- cte在复杂业务场景下的最佳实践方案
1、成果收益
本最佳实践已取得的成果或预期收益。
简单说,简化了复杂的sql查询,提升了复杂查询的可读性和复用性。
2、背景
讲述一下问题或痛点,为什么要做这件事。
计费规则根据险种进行数据统计,计费规则从地区到具体险种配置,地区-计费-参保方案-参保方案详情,层级深,关系一层套一层,很多表数据需要复用,只能反反复复的查询。最后写出一个层层嵌套的sql,看也看不懂,改也改不动。
传统方案面临三大难题:
- 嵌套黑洞:5层以上子查询导致sql可读性断崖式下降
- 重复炼狱:相同子查询在多个地方重复出现
- 调试噩梦:修改一个字段需要追踪多级嵌套
3、什么是cte
公共表表达式(common table expression,简称 cte),cte 是在sql查询中定义的一个临时结果集,cte 通常用于
- 多层嵌套子查询的简化
- 递归查询(如树形结构遍历,mysql 8.0.1+支持递归cte)
- 多次复用同一子查询结果
cte 的定义部分类似于创建一个临时视图,但其生命周期仅限于当前查询。通过 with 创建临时命名结果集,with 子句更轻量,适合在单个查询中复用中间结果,提升复杂查询的可读性和复用性。
4、cte如何使用
基本语法
with cte_name as (
-- 子查询
select ...
)
select ...
from cte_name;cte_name:cte 的名称,就是临时表的名称。- 子查询:定义 cte 的结果集。
- 后续查询:可以引用 cte 名称。
注意with是不需要分号结尾的,当分号出现时就意味着当前的sql生命周期已经结束了。
多个 cte 的使用
可以在一个 with 子句中定义多个 cte,用逗号分隔。
with
cus_totals as (
select cus_id, sum(amount) as total_amount
from orders
group by cus_id
),
latest_orders as (
select cus_id, max(order_date) as latest_date
from orders
group by cus_id
)
select t.cus_id, t.total_amount, l.latest_date
from cus_totals t
join latest_orders l on t.cus_id = l.cus_id;示例:
- 第一个 cte:计算每个客户的订单总金额。
- 第二个 cte:计算每个客户的最新订单日期。
- 最终查询:连接两个 cte,生成结果。
5、经验总结
主要用于数据导出的场景,更方便多表查询的场景。
到此这篇关于mysql sql查询新模式cte使用详解的文章就介绍到这了,更多相关mysql cte使用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论