MySQL 8 的 SQL 语法新特性

下面是一个表格,汇总了 MySQL 8 的主要 SQL 语法新特性:

功能类别 新增的 SQL 语法/功能点 简要说明与示例
公共表表达式 (CTE) WITH ... AS (...) 定义临时结果集供主查询使用。支持递归(Recursive CTE)125。
窗口函数 OVER() 子句及相关函数 对查询结果的子集(窗口)进行计算,如 ROW_NUMBER(), RANK(), LEAD(), LAG() 等125。
JSON 功能增强 JSON_ARRAYAGG(), JSON_OBJECTAGG() 聚合函数,将行数据聚合为 JSON 数组或对象125。
->> (内联路径操作符) 等价于 JSON_UNQUOTE(JSON_EXTRACT()),直接输出无引号的 JSON 值125。
正则表达式增强 REGEXP_LIKE(), REGEXP_INSTR(), REGEXP_REPLACE(), REGEXP_SUBSTR() 提供更强大且符合 Unicode 标准的正则表达式处理125。
聚合函数增强 GROUPING() 函数 GROUP BY ... WITH ROLLUP 一起使用,区分结果中的汇总行和明细行。
函数索引 在索引中使用表达式 对函数或表达式的计算结果创建索引,例如 CREATE INDEX idx_func ON t (UPPER(col));68。
降序索引 明确支持降序索引 DESC(在索引定义中) 优化按降序排序的查询。例如 CREATE INDEX idx_desc ON t (col DESC);126。
隐藏索引 `VISIBLE INVISIBLE`(在索引定义中) 将索引设置为对优化器不可见,用于测试索引必要性而不删除它。例如 ALTER TABLE t ALTER INDEX idx_name INVISIBLE;6。
权限管理增强 角色 (Role) 创建角色并授予权限,然后将角色分配给用户,简化权限管理128。

🧠 一些细节和示例

  • 公共表表达式 (CTE) :允许在查询前定义一个临时的命名结果集,提高复杂查询的可读性和可维护性。支持递归查询,处理树状或层次结构数据非常方便125。
sql 复制代码
```sql
-- 非递归CTE
WITH department_salaries AS (
  SELECT department_id, SUM(salary) AS total_salary
  FROM employees
  GROUP BY department_id
)
SELECT * FROM department_salaries WHERE total_salary > 100000;

-- 递归CTE(示例:生成数字序列)
WITH RECURSIVE number_sequence(n) AS (
  SELECT 1
  UNION ALL
  SELECT n + 1 FROM number_sequence WHERE n < 10
)
SELECT * FROM number_sequence;
```
  • 窗口函数:允许你对一个与当前行相关的"窗口"内的行进行计算,而不会将结果集合并成单一行125。

    sql 复制代码
    -- 计算每个部门内员工的工资排名
    SELECT 
        employee_name, 
        department_id, 
        salary,
        RANK() OVER (PARTITION BY department_id ORDER BY salary DESC) AS dept_salary_rank
    FROM employees;
  • JSON 功能增强:提供了更多操作和构建 JSON 文档的函数125。

sql 复制代码
```sql
-- 将行聚合为JSON数组和对象
SELECT JSON_ARRAYAGG(employee_name) FROM employees WHERE department_id = 1;
SELECT department_id, JSON_OBJECTAGG(employee_name, salary) FROM employees GROUP BY department_id;

-- 使用->>操作符直接提取并取消引用JSON值
SELECT data->>'$.name' AS name FROM users;
```
  • 正则表达式增强:新的正则表达式函数提供了更强大、更符合标准的功能125。

sql -- 使用新REGEXP函数进行匹配和替换 SELECT REGEXP_REPLACE(phone_number, '^(\d{3})(\d{4})(\d{4})$', '\1-\2-\3') AS formatted_phone FROM customers;

  • 函数索引:可以对列的函数表达式创建索引,加速基于这些表达式的查询68。

    sql 复制代码
    -- 对名字的大写形式创建索引,加速不区分大小写的查询
    CREATE INDEX idx_upper_last_name ON employees (UPPER(last_name));
    -- 查询时使用索引
    SELECT * FROM employees WHERE UPPER(last_name) = 'SMITH';
  • 降序索引与隐藏索引

sql 复制代码
```sql
-- 创建降序索引优化ORDER BY ... DESC查询
CREATE INDEX idx_created_at_desc ON orders (created_at DESC);

-- 隐藏一个索引测试性能
ALTER TABLE orders ALTER INDEX idx_created_at_desc INVISIBLE;
-- 再次显示索引
ALTER TABLE orders ALTER INDEX idx_created_at_desc VISIBLE;
```
  • 角色管理

    sql 复制代码
    -- 创建角色并授予权限
    CREATE ROLE 'report_read_only';
    GRANT SELECT ON report_db.* TO 'report_read_only';
    -- 将角色授予用户
    GRANT 'report_read_only' TO 'some_user'@'%';
    -- 设置默认角色(可选,MySQL 8.0需要)
    SET DEFAULT ROLE 'report_read_only' TO 'some_user'@'%';

使用注意事项

  • 兼容性 :在升级到 MySQL 8 或使用新语法前,务必评估其对现有应用的影响。例如,MySQL 8 中 GROUP BY 子句不再进行隐式排序 ,若需排序必须显式加上 ORDER BY36。
  • 性能:虽然新特性(如函数索引、降序索引)能提升性能,但也需合理使用,避免不必要的资源消耗。
  • 学习成本:团队需要时间熟悉和掌握这些新语法和特性。

本文由 dblens.com 知识分享,🚀 dblens for MySQL- AI大模型深度融合的一款免费的MySQL可视化GUI数据库连接管理软件。

相关推荐
短剑重铸之日21 分钟前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
码界奇点2 小时前
基于Flask与OpenSSL的自签证书管理系统设计与实现
后端·python·flask·毕业设计·飞书·源代码管理
代码匠心3 小时前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
分享牛3 小时前
LangChain4j从入门到精通-11-结构化输出
后端·python·flask
知识即是力量ol4 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传
闻哥4 小时前
深入理解 Spring @Conditional 注解:原理与实战
java·jvm·后端·python·spring
qq_256247055 小时前
Google 账号防封全攻略:从避坑、保号到申诉解封
后端
MX_93595 小时前
使用Spring的BeanFactoryPostProcessor扩展点完成自定义注解扫描
java·后端·spring
弹简特5 小时前
【JavaEE05-后端部分】使用idea社区版从零开始创建第一个 SpringBoot 程序
java·spring boot·后端
爬山算法5 小时前
Hibernate(81)如何在数据同步中使用Hibernate?
java·后端·hibernate