当前位置: 首页 > news >正文

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。
隐藏索引`VISIBLEINVISIBLE`(在索引定义中)将索引设置为对优化器不可见,用于测试索引必要性而不删除它。例如 ALTER TABLE t ALTER INDEX idx_name INVISIBLE;6。
权限管理增强角色 (Role)创建角色并授予权限,然后将角色分配给用户,简化权限管理128。

🧠 一些细节和示例

  • 公共表表达式 (CTE) :允许在查询前定义一个临时的命名结果集,提高复杂查询的可读性和可维护性。支持递归查询,处理树状或层次结构数据非常方便125。

在这里插入图片描述

-- 非递归CTE
WITH department_salaries AS (SELECT department_id, SUM(salary) AS total_salaryFROM employeesGROUP BY department_id
)
SELECT * FROM department_salaries WHERE total_salary > 100000;-- 递归CTE(示例:生成数字序列)
WITH RECURSIVE number_sequence(n) AS (SELECT 1UNION ALLSELECT n + 1 FROM number_sequence WHERE n < 10
)
SELECT * FROM number_sequence;
  • 窗口函数:允许你对一个与当前行相关的“窗口”内的行进行计算,而不会将结果集合并成单一行125。

    -- 计算每个部门内员工的工资排名
    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。
    在这里插入图片描述

-- 将行聚合为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。
    在这里插入图片描述
 -- 使用新REGEXP函数进行匹配和替换SELECT REGEXP_REPLACE(phone_number, '^(\d{3})(\d{4})(\d{4})$', '\1-\2-\3') AS formatted_phone FROM customers;
  • 函数索引:可以对列的函数表达式创建索引,加速基于这些表达式的查询68。

    -- 对名字的大写形式创建索引,加速不区分大小写的查询
    CREATE INDEX idx_upper_last_name ON employees (UPPER(last_name));
    -- 查询时使用索引
    SELECT * FROM employees WHERE UPPER(last_name) = 'SMITH';
    
  • 降序索引与隐藏索引
    在这里插入图片描述

-- 创建降序索引优化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;
  • 角色管理

    -- 创建角色并授予权限
    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数据库连接管理软件。

http://www.dtcms.com/a/359434.html

相关文章:

  • WebSocket的基本使用方法
  • 异步编程以及promise的一些拓展
  • SpringBoot学习笔记(上)——自动装配原理、自定义 springboot-starter、配置文件编写
  • 螺旋曲面交线投影切线角度计算与分析
  • Junior Engineer浅谈CAS
  • 联合体Union
  • OpenStack 03:创建实例
  • LeetCode100-160相交链表【链表介绍】
  • 基于Adaboost集成学习与SHAP可解释性分析的分类预测
  • 洞悉边界:软件测试中边界值分析的艺术与科学
  • kotlin - 2个Activity实现平行视图,使用SplitPairFilter
  • 代码随想录算法训练营五十三天|图论part11
  • Linux中的ss命令
  • 项目跑起来之前的那些事
  • 【Spring】ApplicationListener监听器
  • BigDecimal账户分布式原子操作
  • Linux 中进入 root 权限
  • dayjs 常用方法总结
  • Nginx 502 Bad Gateway:从 upstream 日志到 FastCGI 超时复盘
  • 【大数据技术实战】流式计算 Flink~生产错误实战解析
  • vim-plugin AI插件
  • Playwright Python教程:基础篇
  • 秋招笔记-8.31
  • 在集群级别应用 Pod 安全标准
  • 【MySQL】练习12-4:启用GTID并配置循环复制
  • Conda相关的用法
  • 人工智能之数学基础:连续型随机变量
  • Langflow 评估与迭代技术深度分析
  • 3DES加解密的算法Java Python Golang
  • 【大模型面试宝典之微调篇】(一)