MySQL8.0新特性
第十八章_MySQL8.0新特性
1.新特性概述
1. 数据库管理和存储
1.1 数据字典
-
特性: MySQL 8.0 使用统一的数据字典存储元数据(如表、列、索引等),并将其存储在 InnoDB 表中。
-
优点
:
-
提升性能:减少对文件系统的依赖。
-
提高一致性:避免元数据与实际数据不同步的问题。
-
1.2 隐式主键
-
特性: 当创建没有主键的表时,MySQL 8.0 会自动生成一个隐藏的主键。
-
优点
:
-
提高数据访问效率。
-
减少手动维护主键的麻烦。
-
2. SQL 语言增强
2.1 窗口函数
-
特性: 支持窗口函数(
OVER子句),允许在查询中执行复杂的分析操作。 -
示例
:
SELECT name, salary, RANK() OVER (PARTITION BY department ORDER BY salary DESC) AS rank FROM employees; -
优点
:
-
适合排名、累计总和、移动平均等分析场景。
-
2.2 公用表表达式(CTE)
-
特性: 支持递归和非递归 CTE(
WITH子句)。 -
示例
:
WITH RECURSIVE cte AS (SELECT 1 AS nUNION ALLSELECT n + 1 FROM cte WHERE n < 5 ) SELECT * FROM cte; -
优点
:
-
提高查询的可读性和复用性。
-
递归查询支持层级结构数据处理。
-
2.3 JSON 增强
-
特性: 增强了对 JSON 数据类型的支持,包括 JSON 表达式、函数和索引。
-
示例
:
SELECT JSON_EXTRACT(json_column, '$.key') AS value FROM my_table;
-
新增函数:
JSON_TABLE()、JSON_ARRAYAGG()、JSON_OBJECTAGG()等。 -
优点
:
-
更高效地处理半结构化数据。
-
2.4 默认值表达式
-
特性: 支持列的默认值为表达式。
-
示例
:
CREATE TABLE orders (id INT AUTO_INCREMENT PRIMARY KEY,order_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP );
-
优点
:
-
动态设置默认值,更灵活。
-
3. 性能优化
3.1 索引增强
-
特性: 支持隐式列的降序索引(
DESC)。 -
优点
:
-
提高查询性能,尤其是在排序需求较多的场景中。
-
3.2 持久化生成列
-
特性: 支持生成列的持久化(
STORED)。 -
优点
:
-
减少存储开销,同时支持复杂计算。
-
3.3 查询性能改进
-
特性: 优化器改进了查询计划的生成,支持更复杂的优化场景,如物化 CTE。
-
优点
:
-
提高复杂查询的执行效率。
-
4. 安全性增强
4.1 账户锁定和密码策略
-
特性: 支持用户账户锁定(
ACCOUNT LOCK)和密码过期策略。 -
示例
:
ALTER USER 'user'@'localhost' ACCOUNT LOCK;
-
优点
:
-
提高账户安全性,防止暴力破解。
-
4.2 默认使用 caching_sha2_password
-
特性: 默认身份验证插件更改为
caching_sha2_password。 -
优点
:
-
提高密码存储的安全性。
-
4.3 动态权限
-
特性: 支持动态权限,可以更细粒度地控制用户操作。
-
示例
:
GRANT BACKUP_ADMIN ON *.* TO 'user'@'localhost';
-
优点
:
-
更灵活的权限管理。
-
5. JSON 和 GIS 数据类型改进
5.1 JSON 数据类型
-
新增 JSON 函数,如
JSON_TABLE(),用于将 JSON 数据转换为关系型数据表。 -
支持 JSON 部分更新,提升性能。
5.2 GIS 数据类型
-
特性: 改进了对 GIS 数据类型的支持,包括更高效的空间索引。
-
优点
:
-
更适合地理位置相关的应用场景。
-
6. 开发工具和可用性
6.1 错误日志管理
-
特性: 错误日志支持多种格式(如 JSON)和日志轮换。
-
优点
:
-
提高日志分析和管理的效率。
-
6.2 系统变量持久化
-
特性: 支持动态系统变量的持久化。
-
示例
:
SET PERSIST max_connections = 200;
-
优点
:
-
重启后仍然保留变量值,无需修改配置文件。
-
7. 其他改进
7.1 数据复制
-
支持基于事务的复制,增强了复制的稳定性和一致性。
-
支持并行复制,提高复制性能。
7.2 临时表改进
-
临时表默认使用 InnoDB 存储引擎,提高事务支持能力。
2.新特性1: 窗口函数
2.2 排名函数
用于给数据分配排名:
-
ROW_NUMBER(): 为每行分配唯一的序号。 -
RANK(): 按排序规则排名,值相同的行具有相同的排名,下一排名会跳过。 -
DENSE_RANK(): 与RANK()类似,但不会跳过排名。 -
NTILE(n): 将数据划分为n个桶,并为每行分配桶号。
2.3 偏移函数
用于访问窗口内其他行的数据:
-
LAG(column, offset, default): 获取当前行之前第offset行的值。 -
LEAD(column, offset, default): 获取当前行之后第offset行的值。 -
FIRST_VALUE(column): 获取窗口中第一行的值。 -
LAST_VALUE(column): 获取窗口中最后一行的值。
2.4 比率和累计分布
-
PERCENT_RANK(): 当前行在分组中的百分比排名。 -
CUME_DIST(): 当前行及之前的行在分组中的累计分布比例。
相关文章:
MySQL8.0新特性
第十八章_MySQL8.0新特性 1.新特性概述 1. 数据库管理和存储 1.1 数据字典 特性: MySQL 8.0 使用统一的数据字典存储元数据(如表、列、索引等),并将其存储在 InnoDB 表中。 优点 : 提升性能:减少对文件系统的依赖。 提高一致…...
Oracle EBS GL定期盘存WIP日记账无法过账数据修复
系统环境 RDBMS : 12.1.0.2.0 Oracle Applications : 12.2.6 问题症状 用户反映来源为“定期盘存”和类别为“WIP”的日记账无法过账,标准日记账的界面上的过账按钮灰色不可用。但是,在超级用户职责下,该日记账又可以过账,细心检查发现该业务实体下有二个公司段值15100和…...
【绝对无坑】Mongodb获取集合的字段以及数据类型信息
Mongodb获取集合的字段以及数据类型信息 感觉很LOW的一个数据仓工具seatunel,竟然不能自动读取mongodb的表结构信息,需要手工创建。 然鹅,本人对mongodb也是新手,很多操作也不知所措,作为一个DBA,始终还是…...
【Git版本控制器--1】Git的基本操作--本地仓库
目录 初识git 本地仓库 认识工作区、暂存区、版本库 add操作与commit操作 master文件与commit id 修改文件 版本回退 撤销修改 删除文件 初识git Git 是一个分布式版本控制系统,主要用于跟踪文件的更改,特别是在软件开发中。 为什么要版本…...
C++并发编程之无锁数据结构及其优缺点
在C并发编程中,无锁数据结构(Lock-free Data Structures)是指那些在实现中不使用互斥锁(如std::mutex)来保证线程安全的数据结构。相反,它们利用原子操作和内存模型来确保多线程环境下的正确性和高效性。下…...
Ubuntu上,ffmpeg如何使用cuda硬件解码、编码、转码加速
本文使用 Ubuntu 环境。Ubuntu 直接使用 APT 安装的就支持 CUDA 加速。本文使用这样下载的版本进行演示,你自己编译或者其他源的版本可能会不同。 ffmpeg 的一些介绍,以及 macOS 版本的 ffmpeg 硬件加速请见《macOS上如何安装(不需要编译安装…...
rclone,云存储备份和迁移的瑞士军刀,千字常文解析,附下载链接和安装操作步骤...
一、什么是rclone? rclone是一个命令行程序,全称:rsync for cloud storage。是用于将文件和目录同步到云存储提供商的工具。因其支持多种云存储服务的备份,如Google Drive、Amazon S3、Dropbox、Backblaze B2、One Drive、Swift、…...
Ubuntu | 系统软件安装系列指导说明
文章目录 Ubuntu 系统软件安装系列指导说明工具系列1. Docker 与 Docker-Compose部署与安装 环境系列1. Golang部署与安装 数据库系列1. PostgreSQL17.2源码部署与安装 Ubuntu 系统软件安装系列指导说明 工具系列 1. Docker 与 Docker-Compose部署与安装 链接 环境系列 1…...
队列(算法十三)
简介 几乎没有单纯之考察队列的,队列一般只作为一个辅助工具 队列常服务于BFS queue接口 1.N叉树的层序遍历 link: 思路: 队列 层序遍历即可 code /* // Definition for a Node. class Node { public:int val;vector<Node*> children;Node()…...
vLLM私有化部署大语言模型LLM
目录 一、vLLM介绍 二、安装vLLM 1、安装环境 2、安装步骤 三、运行vLLM 1、运行方式 2、切换模型下载源 3、运行本地已下载模型 四、通过http访问vLLM 一、vLLM介绍 vLLM(官方网址:https://www.vllm.ai)是一种用于大规模语言模型&#x…...
OpenAI Whisper:语音识别技术的革新者—深入架构与参数
当下语音识别技术正以前所未有的速度发展,极大地推动了人机交互的便利性和效率。OpenAI的Whisper系统无疑是这一领域的佼佼者,它凭借其卓越的性能、广泛的适用性和创新的技术架构,正在重新定义语音转文本技术的规则。今天我们一起了解一下Whi…...
基于当前最前沿的前端(Vue3 + Vite + Antdv)和后台(Spring boot)实现的低代码开发平台
项目是一个基于当前最前沿的前端技术栈(Vue3 Vite Ant Design Vue,简称Antdv)和后台技术栈(Spring Boot)实现的低代码开发平台。以下是对该项目的详细介绍: 一、项目概述 项目名称:lowcode-s…...
【Rust】错误处理机制
目录 思维导图 引言 一、错误处理的重要性 1.1 软件中的错误普遍存在 1.2 编译时错误处理要求 二、错误的分类 2.1 可恢复错误(Recoverable Errors) 2.2 不可恢复错误(Unrecoverable Errors) 三、Rust 的错误处理机制 3…...
Logback日志技术
Logback日志技术 日志 日志(Logging)是软件开发和运维中用于记录系统或应用程序运行期间发生的运行信息、状态变化、错误信息等的一种机制,这种记录的方式就好像我们日常生活中写日记一样。它提供了一种持久化的方式,使得开发者…...
9分布式微服务架构
分布式微服务架构不光需要从架构上的设计优化系统,还要在编码上优化达到最好的效果 中心化的设计 中心化的设计比较简单,分布式集群中的角色分为两种,管理者和被管理者。 在一个分布式或者集群中,管理者角色管理着其他处理实际…...
Leecode刷题C语言之统计重新排列后包含另一个字符串的子字符串数目②
执行结果:通过 执行用时和内存消耗如下: void update(int *diff, int c, int add, int *cnt) {diff[c] add;if (add 1 && diff[c] 0) {// 表明 diff[c] 由 -1 变为 0(*cnt)--;} else if (add -1 && diff[c] -1) {// 表明 diff[c] 由 0 变为 -…...
HTML和CSS相关的问题,为什么页面加载速度慢?
页面加载速度慢是网站优化中一个常见的问题,可能由于多种原因,包括HTML和CSS的代码编写方式、资源的加载顺序、页面渲染的复杂性等。以下是一些常见的原因和优化方法,结合实际项目代码示例进行讲解。 1. 过多的资源请求 如果页面包含大量的…...
LiveGBS流媒体平台GB/T28181常见问题-没有收到视频流播放时候提示none rtp data receive未收到摄像头推流如何处理?
LiveGBS没有收到视频流播放时候提示none rtp data receive未收到摄像头推流如何处理? 1、none rtp data receive2、搭建GB28181视频直播平台 1、none rtp data receive LiveSMS 收不到下级推流 首先需要排查服务器端 UDP & TCP 30000-30249 端口是否开放其次排…...
Flask表单处理与验证
Flask是一个轻量级的Python框架,它通过扩展库提供了对表单处理与验证的支持。WTForms是一个流行的Flask扩展库,用于创建和验证Web表单。它提供了一种声明式的方法来定义表单结构和验证逻辑,使得表单处理更为简洁和优雅。下面,我们…...
正泰电工携手图扑:变电站数字孪生巡检平台
随着电力行业的快速发展与智能化转型,传统的人工巡检方式难以匹配现代电网对于效率、安全和精细化管理的高标准要求。在此背景下,构建智慧变电站巡检系统已成为推动变电站智能化进程、实现高效运营和保障电网可靠性的重要战略。 图扑软件与正泰电工联合…...
Linux简单的操作
ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...
C++ 基础特性深度解析
目录 引言 一、命名空间(namespace) C 中的命名空间 与 C 语言的对比 二、缺省参数 C 中的缺省参数 与 C 语言的对比 三、引用(reference) C 中的引用 与 C 语言的对比 四、inline(内联函数…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
HarmonyOS运动开发:如何用mpchart绘制运动配速图表
##鸿蒙核心技术##运动开发##Sensor Service Kit(传感器服务)# 前言 在运动类应用中,运动数据的可视化是提升用户体验的重要环节。通过直观的图表展示运动过程中的关键数据,如配速、距离、卡路里消耗等,用户可以更清晰…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...
【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论
路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中(图1): mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...
Python Einops库:深度学习中的张量操作革命
Einops(爱因斯坦操作库)就像给张量操作戴上了一副"语义眼镜"——让你用人类能理解的方式告诉计算机如何操作多维数组。这个基于爱因斯坦求和约定的库,用类似自然语言的表达式替代了晦涩的API调用,彻底改变了深度学习工程…...
Python 训练营打卡 Day 47
注意力热力图可视化 在day 46代码的基础上,对比不同卷积层热力图可视化的结果 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pypl…...
MySQL的pymysql操作
本章是MySQL的最后一章,MySQL到此完结,下一站Hadoop!!! 这章很简单,完整代码在最后,详细讲解之前python课程里面也有,感兴趣的可以往前找一下 一、查询操作 我们需要打开pycharm …...
工厂方法模式和抽象工厂方法模式的battle
1.案例直接上手 在这个案例里面,我们会实现这个普通的工厂方法,并且对比这个普通工厂方法和我们直接创建对象的差别在哪里,为什么需要一个工厂: 下面的这个是我们的这个案例里面涉及到的接口和对应的实现类: 两个发…...
