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数据库连接管理软件。

相关推荐
星哥说事7 小时前
主流开源协议的权限与限制对比,开源协议到底怎么选
后端
二闹8 小时前
参数传进去后到底变不变?
后端·python
best6668 小时前
中间件是什么?什么场景使用?
后端
花花无缺8 小时前
`api`、`common`、`service`、`web` 分层架构设计
java·后端
Code_Artist8 小时前
说说恶龙禁区Unsafe——绕过静态类型安全检查&直接操作内存的外挂
java·后端·操作系统
二闹8 小时前
别再用错了!深入扒一扒Python里列表和元组那点事
后端·python
编程乐趣9 小时前
基于.Net开发的数据库导入导出的开源项目
后端
赵星星5209 小时前
别再搞混了!深入浅出理解Java线程中start()和run()的本质区别
java·后端
Ray669 小时前
FST
后端