mysql cte_MySQL8的新特性CTE

【瞎BB】

十一长假的最后一天,想到明天要就回去上班了;内心的激动无法用平常的言语来表达,可能是国人的感情向来比较内敛(这个锅不能我一个人背)

也可能是我们比较重行动(Just Do IT)。但... 我还是有写一些什么东西的必要得,那我今天就写两点吧!

1): 趁着十一长假还没有过去,我在这里给大家拜个早年

2): 讲讲MySQL-8.0.x的新特性(公共表表达式)CTE

【CTE有什么牛逼的地方】

1、从SQL的写法上看逻辑更加清晰

2、直接递归

【CTE的语法格式】

CTE的主要思想就先生成临时结果集,以方便后面的使用;与临时表不同的是这个结果集的作用域不是当前session而是当前语句,对!不是

session级是语句级别的

with_clause:WITH [RECURSIVE]cte_name[(col_name [, col_name] ...)] AS(subquery)[, cte_name [(col_name [, col_name] ...)] AS (subquery)] ...

【例子一:朴素使用场景】

假设我们有一个Person表用来保存一些自然人的信息

create table person(id int not null auto_increment primary key,name varchar(16));insert into person(name) values('Tom'),('Jry'),('Bob'),('Foo'),('Bar');select * fromperson;+----+------+

| id | name |

+----+------+

| 1 | Tom |

| 2 | Jry |

| 3 | Bob |

| 4 | Foo |

| 5 | Bar |

+----+------+

5 rows in set (0.00 sec)

如果我们要查询id可以被2整除的那些行,通常我们可以这样写SQL

select name from person where id % 2 = 0;+------+

| name |

+------+

| Jry |

| Foo |

+------+

2 rows in set (0.00 sec)

如果出于某种不可描述的压力,一定要让你用CTE表达式来写的话,你也可以样混过去

with ct(name) as (select name from person where id % 2 = 0) select name fromct;+------+

| name |

+------+

| Jry |

| Foo |

+------+

2 rows in set (0.00 sec)

事实上CTE不只是可以用于select语句中,update,delete,insert也都是支持的,你只要知道CTE代表的是一个结果集就好了,通常就

不会用错。

还是出现某种不可描述的压力,要把所有id可以被2整除的公民的name改成"Hello SQL",CTE要硬上了哈!

with ct(id) as (select name from person where id % 2 = 0) update person,ct set person.name="Hello SQL" where person.id =ct.id;

Query OK,2 rows affected (0.08sec)

Rows matched:2 Changed: 2 Warnings: 0

select * fromperson;+----+-----------+

| id | name |

+----+-----------+

| 1 | Tom |

| 2 | Hello SQL |

| 3 | Bob |

| 4 | Hello SQL |

| 5 | Bar |

+----+-----------+

5 rows in set (0.00 sec)

【例子二:递归场景】

还是直接上比较学院派的例子吧、反正牛逼的我也想不出来!直接生成一个斐波那契数列吧!

mysql> with recursive fib as(-> select 0 as x, 1 asy-> union all

-> select

-> fib.y asx,-> fib.x+fib.y asy-> from fib where fib.x < 20)-> select y as n fromfib;+------+

| n |

+------+

| 1 |

| 1 |

| 2 |

| 3 |

| 5 |

| 8 |

| 13 |

| 21 |

| 34 |

+------+

9 rows in set (0.00 sec)

【参考文档】

【学习交流】

-----------------------------http://www.sqlpy.com-------------------------------------------------

6c228ace4f031be575c5734ab4df177b.png

055aa7891acbc69066f84d32bb32f259.png

-----------------------------http://www.sqlpy.com-------------------------------------------------

----

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
限时福利1:购课进答疑群专享柳峰(刘运强)老师答疑服务 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值