MySQL基础入门:MySQL简介与环境搭建
引言
在数字化转型浪潮中,MySQL作为数据存储的"基石引擎",支撑着从电商交易到金融风控的各类核心业务。其高并发处理能力、灵活的架构设计及跨平台兼容性,使其成为开发者技术栈中的"常青树"。本章节将通过历史溯源、技术对比、环境实战、服务运维及工具精研五大维度,构建完整的MySQL认知体系,助你从"数据库小白"跃升为"全栈DBA"。💡✨
一、MySQL历史与版本演进
1.1 里程碑事件
- 1995年开源:由Monty Widenius团队发布,采用GPL协议开启开源数据库时代
- 2008年Sun收购:MySQL AB公司被Sun Microsystems以10亿美元收购,奠定企业级市场基础
- 2010年Oracle并购:Oracle收购Sun后,MySQL进入双轨战略(社区版/企业版)
- 2016年MySQL 8.0发布:引入原子DDL、窗口函数、CTE等革命性特性
1.2 版本特性对比
版本 | 核心改进 | 典型应用场景 |
---|---|---|
5.7 | 性能提升2倍,JSON支持,GIS增强 | 传统Web应用、日志分析 |
8.0 | 原子DDL,InnoDB集群,文档存储 | 微服务架构、实时数据分析 |
社区版 | 开源免费,适合中小型项目 | 初创企业、开源项目 |
企业版 | 高可用插件,审计日志,线程池 | 金融、电信等核心业务系统 |
1.3 版本选择策略
- 开发测试:优先使用最新稳定版(如8.0.33)
- 生产环境:根据业务需求选择版本(如金融系统建议使用5.7 LTS)
- 升级路径:5.6→5.7→8.0分阶段升级,规避兼容性问题
二、MySQL与其他数据库对比
2.1 功能维度对比矩阵
特性 | MySQL | PostgreSQL | Oracle | MongoDB |
---|---|---|---|---|
事务隔离级别 | 支持READ COMMITTED等4级 | 支持SERIALIZABLE最高级 | 支持RAC集群事务 | 多文档事务支持较弱 |
复杂查询 | 依赖索引优化 | 支持CTE、窗口函数 | 支持分析函数 | 聚合查询效率较低 |
扩展性 | 分库分表+中间件 | 扩展插件机制 | RAC集群 | 水平分片+自动Sharding |
2.2 典型场景选型建议
- 电商秒杀系统:MySQL 8.0 + Redis缓存,通过
SELECT * FROM orders WHERE user_id=1001 FOR UPDATE
实现乐观锁 - 金融对账系统:PostgreSQL 16 + JSONB字段,通过
WITH RECURSIVE
递归查询实现树形结构数据 - 物联网设备监控:MongoDB 6.0 + 时序集合,通过
$match
+$group
聚合管道实现分钟级数据统计
三、MySQL安装与配置
3.1 Windows平台
1. 准备工作
- 系统要求:
- Windows 10/11 64位(建议专业版)
- 至少4GB内存(生产环境建议8GB+)
- 预留10GB磁盘空间(数据目录建议SSD)
- 卸载残留(若重装):
sc query mysql # 检查服务是否存在 net stop mysql # 停止服务 sc delete mysql # 删除服务 rd /s /q "C:\Program Files\MySQL\" # 删除安装目录 rd /s /q "C:\ProgramData\MySQL\" # 删除数据目录(隐藏文件夹)
2. 安装步骤
-
下载安装包
- 访问MySQL官网,选择:
- Installer类型:
mysql-installer-community-8.4.25.0.msi
(约420MB) - 版本:MySQL Community Server 8.4.25
- Installer类型:
- 访问MySQL官网,选择:
-
安装配置
- 安装类型:选择
Custom
(自定义安装) - 核心组件:
- MySQL Server 8.4.25-X64
- MySQL Workbench 8.4 CE
- MySQL Shell 8.4
- 配置项:
- 连接方式:
Standalone MySQL Server
- 字符集:
utf8mb4
(支持完整Unicode) - 端口:默认
3306
(可修改为3307
避免冲突) - 认证插件:
- 开发环境:
mysql_native_password
(兼容旧客户端) - 生产环境:
caching_sha2_password
(默认,安全性更高)
- 开发环境:
- 连接方式:
- 安装类型:选择
-
环境变量配置
- 添加系统变量:
- 变量名:
MYSQL_HOME
- 变量值:
C:\Program Files\MySQL\MySQL Server 8.4
- 变量名:
- 修改
Path
变量,添加:%MYSQL_HOME%\bin
- 添加系统变量:
-
验证安装
mysql --version # 应显示8.4.25版本 mysql -u root -p # 输入密码后进入命令行
3.2 Linux(Ubuntu)平台
1. 环境准备(Ubuntu 22.04 LTS示例)
# 1. 更新系统
sudo apt update && sudo apt upgrade -y# 2. 安装依赖
sudo apt install -y wget gnupg2 lsb-release# 3. 添加MySQL APT仓库
wget https://dev.mysql.com/get/mysql-apt-config_0.8.25-1_all.deb
sudo dpkg -i mysql-apt-config_0.8.25-1_all.deb
# 选择MySQL 8.4 Server,其他保持默认# 4. 更新仓库并安装
sudo apt update
sudo apt install -y mysql-server=8.4.25-1ubuntu22.04
2. 安全加固
sudo mysql_secure_installation
# 配置项:
# - 启用VALIDATE PASSWORD插件(强密码策略)
# - 移除匿名用户
# - 禁止root远程登录
# - 删除测试数据库
# - 刷新权限表
3. 配置文件优化
# /etc/mysql/mysql.conf.d/mysqld.cnf
[mysqld]
# 基础配置
user = mysql
basedir = /usr
datadir = /var/lib/mysql
socket = /var/run/mysqld/mysqld.sock
pid-file = /var/run/mysqld/mysqld.pid# 性能优化
innodb_buffer_pool_size = 4G # 内存的50-70%
innodb_log_file_size = 1G
innodb_flush_log_at_trx_commit = 1
sync_binlog = 1
max_connections = 500# 字符集
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci# 日志配置
slow_query_log = 1
slow_query_log_file = /var/log/mysql/mysql-slow.log
long_query_time = 2
4. 重启服务
sudo systemctl restart mysql
sudo systemctl enable mysql # 开机自启
3.3 macOS平台
1. Homebrew安装(推荐)
# 1. 安装Homebrew(若未安装)
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"# 2. 安装MySQL
brew install mysql@8.4# 3. 启动服务
brew services start mysql@8.4# 4. 安全配置
mysql_secure_installation
# 配置项:
# - 设置root密码
# - 移除匿名用户
# - 禁止root远程登录
# - 删除测试数据库
2. 配置文件路径
- 配置文件:
/opt/homebrew/etc/my.cnf
- 数据目录:
/opt/homebrew/var/mysql
3. 环境变量配置
echo 'export PATH="/opt/homebrew/opt/mysql@8.4/bin:$PATH"' >> ~/.zshrc
source ~/.zshrc
四、MySQL服务管理
4.1 服务控制命令集
场景 | Windows命令 | Linux/macOS命令 |
---|---|---|
启动 | net start mysql | systemctl start mysqld |
停止 | net stop mysql | systemctl stop mysqld |
重启 | net restart mysql | systemctl restart mysqld |
查看状态 | sc query mysql | systemctl status mysqld |
4.2 常见故障解决方案
1. 错误1045(Access Denied)
- 原因:密码错误或用户无权限
- 解决方案:
# 1. 停止MySQL服务 sudo systemctl stop mysql # Linux/macOS net stop mysql # Windows# 2. 跳过权限表启动 sudo mysqld_safe --skip-grant-tables & # Linux/macOS mysqld --skip-grant-tables # Windows# 3. 修改密码 mysql -u root FLUSH PRIVILEGES; ALTER USER 'root'@'localhost' IDENTIFIED BY 'NewP@ssw0rd!';
2. 端口冲突(3306被占用)
- 检查端口:
netstat -ano | findstr 3306 # Windows sudo lsof -i :3306 # Linux/macOS
- 解决方案:
- 修改MySQL端口(
my.cnf
中设置port=3307
) - 终止占用进程
- 修改MySQL端口(
3. 字符集乱码
- 配置项:
[mysqld] character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci[client] default-character-set = utf8mb4[mysql] default-character-set = utf8mb4
五、客户端工具使用
5.1 MySQL Workbench进阶使用
- 可视化建模:
- 逆向工程:将现有数据库生成ER图
- 正向工程:从ER图生成SQL脚本
- 性能调优:
- 使用Visual Explain可视化执行计划
- 通过Performance Dashboard监控实时指标
5.2 命令行客户端高阶技巧
- 交互式提示符:
mysql -u root -p --pager="less -S" # 分页显示长查询结果
- 历史记录管理:
# 在~/.my.cnf中添加 [mysql] prompt=\\u@\\h [\\d]>\\_
- 批量执行:
mysql -u root -p < init_script.sql
5.3 第三方工具推荐
- DBeaver:跨平台开源数据库工具,支持多种数据库
- Navicat Premium:商业工具,提供数据迁移、报表生成等高级功能
- Adminer:轻量级PHP应用,适合快速部署
总结 🎯
通过本次深度学习,我们完成了从MySQL"理论认知"到"实战部署"的完整闭环:
1️⃣ 历史演进:理解开源数据库的进化逻辑
2️⃣ 技术选型:掌握不同场景下的数据库决策树
3️⃣ 环境搭建:实现多平台自动化部署与优化
4️⃣ 运维监控:构建从启动到备份的全生命周期管理
5️⃣ 工具精研:掌握图形化与命令行的高效协作模式
愿你在MySQL的星辰大海中,持续精进,成为数据库领域的"架构大师"!🌌🚀
PS:如果你在学习过程中遇到问题,别慌!欢迎在评论区留言,我会尽力帮你解决!😄
相关文章:
MySQL基础入门:MySQL简介与环境搭建
引言 在数字化转型浪潮中,MySQL作为数据存储的"基石引擎",支撑着从电商交易到金融风控的各类核心业务。其高并发处理能力、灵活的架构设计及跨平台兼容性,使其成为开发者技术栈中的"常青树"。本章节将通过历史溯源、技术…...
无人机避障——(运动规划部分)深蓝学院动力学kinodynamic A* 3D算法理论解读(附C++代码)
开源代码链接:GitHub - Perishell/motion-planning 效果展示: ROS 节点展示全局规划和轨迹生成部分: Kinodynamic A*代码主体: int KinoAstar::search(Eigen::Vector3d start_pt, Eigen::Vector3d start_vel,Eigen::Vector3d en…...
电脑声音小怎么调大 查看声音调整方法
电脑是我们工作学习经常需要用到的工具,同时电脑也可以播放音乐、视频、游戏等,享受声音的效果。但是,有些电脑的声音很小,即使把音量调到最大,也听不清楚,这让我们很苦恼。那么,电脑声音小怎么…...
无人机信号监测系统技术解析
一、模块技术要点 1. 天线阵列与信号接收模块 多频段自适应切换:采用天线阵列模块,根据复杂地形和不同频段自动切换合适的天线,提升信号接收灵敏度。 双天线测向技术:通过双天线的RSSI(信号接收强度)差值…...
Excel的详细使用指南
### **一、Excel基础操作** #### **1. 界面与基本概念** - **工作簿(Workbook)**:一个Excel文件(扩展名.xlsx)。 - **工作表(Worksheet)**:工作簿中的单个表格(默认名…...
基于SSM实现的健身房系统功能实现十六
一、前言介绍: 1.1 项目摘要 随着社会的快速发展和人们健康意识的不断提升,健身行业也在迅速扩展。越来越多的人加入到健身行列,健身房的数量也在不断增加。这种趋势使得健身房的管理变得越来越复杂,传统的手工或部分自动化的管…...
序列化和反序列化(hadoop)
1.先将上一个博客的Student复制粘贴后面加上H 在StudentH中敲下面代码 package com.example.sei; import org.apache.hadoop.io.Writable; import java.io.DataInput; import java.io.DataOutput; import java.io.IOException; //学生类,姓名,年龄 //支…...
大模型MCP_MCP从流式SSE到流式HTTP_1.8.0支持流式HTTP交互_介绍_从应用到最优--人工智能工作笔记0245
从最开始的大模型时代,到现在MCP,大模型技术,人工智能技术迭代真的非常快 之前的大模型更像一个大脑,能帮大家出点子,然后告诉你思路,你去解决问题,但是 一直不能自己解决问题,后来出来了通用的manus智能体,声称可以解决很多问题.直接操作 一个自带的电脑,但是也有局限性,还…...
docker大镜像优化实战
在 Docker 镜像优化方面,有许多实战技巧可以显著减小镜像体积、提高构建效率和运行时性能。以下是一些实用的优化策略和具体操作方法: 1. 选择合适的基础镜像 策略 使用 Alpine 版本:Alpine 镜像通常只有 5-10MB,比 Ubuntu/Deb…...
【25软考网工】第六章(5)应用层安全协议
博客主页:christine-rr-CSDN博客 专栏主页:软考中级网络工程师笔记 大家好,我是christine-rr !目前《软考中级网络工程师》专栏已经更新三十篇文章了,每篇笔记都包含详细的知识点,希望能帮助到你ÿ…...
RevIN(Reversible Instance Normalization)及其在时间序列中的应用
详细介绍 RevIN(Reversible Instance Normalization)及其在时间序列中的应用 1. RevIN 的定义与背景 RevIN(可逆实例归一化)是一种专门为时间序列预测设计的归一化方法,旨在处理非平稳数据(non-stationar…...
JSON 和 cJSON 库入门教程
第一部分:了解 JSON (JavaScript Object Notation) 什么是 JSON? JSON 是一种轻量级的数据交换格式。它易于人阅读和编写,同时也易于机器解析和生成。 JSON 基于 JavaScript 编程语言的一个子集,但它是一种独立于语言的文本格式…...
Unity 2D 行走动画示例工程手动构建教程-AI变成配额前端UI-完美游戏开发流程
🎮 Unity 2D 行走动画示例工程手动构建教程 ✅ 1. 新建 Unity 项目 打开 Unity Hub: 创建一个新项目,模板选择:2D Core项目名:WalkAnimationDemo ✅ 2. 创建文件夹结构 在 Assets/ 目录下新建以下文件夹:…...
[Java][Leetcode middle] 45. 跳跃游戏 II
这题没做出来,看的答案解析 可以理解为希望采用最少得跳槽次数跳到最高级别的公司。 下标i为公司本身的职级,每个公司可以提供本身等级nums[i]的职级提升。 每次从这些选择中选择自己能够达到最大职级的公司跳槽。 public int jump(int[] nums) {if(nu…...
leetcode 3335. 字符串转换后的长度 I
给你一个字符串 s 和一个整数 t,表示要执行的 转换 次数。每次 转换 需要根据以下规则替换字符串 s 中的每个字符: 如果字符是 z,则将其替换为字符串 "ab"。否则,将其替换为字母表中的下一个字符。例如,a 替…...
Leetcode 3542. Minimum Operations to Convert All Elements to Zero
Leetcode 3542. Minimum Operations to Convert All Elements to Zero 1. 解题思路2. 代码实现 题目链接:3542. Minimum Operations to Convert All Elements to Zero 1. 解题思路 这一题的处理方法其实还是挺好想明白的,其实就是从小到大依次处理各个…...
如何使用C51的Timer0实现定时功能
在C51单片机中,使用定时器0(Timer0)实现定时功能需要以下步骤: 1. 定时器基础知识 时钟源:C51的定时器时钟来源于晶振(如12MHz)。机器周期:1个机器周期 12个时钟周期(1…...
Day1 时间复杂度
一 概念 在 C 中,时间复杂度是衡量算法运行时间随输入规模增长的趋势的关键指标,用于评估算法的效率。它通过 大 O 表示法(Big O Notation) 描述,关注的是输入规模 n 趋近于无穷大时,算法时间增长的主导因…...
PostgreSQL 配置设置函数
PostgreSQL 配置设置函数 PostgreSQL 提供了一组配置设置函数(Configuration Settings Functions),用于查询和修改数据库服务器的运行时配置参数。这些函数为数据库管理员提供了动态管理数据库配置的能力,无需重启数据库服务。 …...
美学心得(第二百七十六集) 罗国正
美学心得(第二百七十六集) 罗国正 (2025年4月) 3275、人类将迎来真、善、美快速发展的时期,人‐机合一的天人合一(可简称为“天人机合一”)的境界已渐露头角,在优秀的人群中迅猛地…...
描述性统计工具 - AxureMost 落葵网
描述性统计工具是用于汇总和分析数据,以更好地了解数据特征的工具1。以下是一些常见的描述性统计工具简介: 描述性统计工具 Excel 基本统计函数:提供了丰富的函数用于计算描述性统计量。例如,AVERAGE 函数用于计算平均值…...
mybatis中${}和#{}的区别
先测试,再说结论 userService.selectStudentByClssIds(10000, "wzh or 11");List<StudentEntity> selectStudentByClssIds(Param("stuId") int stuId, Param("field") String field);<select id"selectStudentByClssI…...
【OpenCV】网络模型推理的简单流程分析(readNetFromONNX、setInput和forward等)
目录 1.模型读取(readNetFromONNX())1.1 初始化解析函数(parseOperatorSet())1.2 提取张量(getGraphTensors())1.3 节点处理(handleNode()) 2.数据准备(blobFromImage() …...
代码随想录算法训练营第三十九天
LeetCode题目: 115. 不同的子序列583. 两个字符串的删除操作72. 编辑距离 其他: 今日总结 往期打卡 115. 不同的子序列 跳转: 115. 不同的子序列 学习: 代码随想录公开讲解 问题: 给你两个字符串 s 和 t ,统计并返回在 s 的 子序列 中 t 出现的个数。 测试用例保…...
InternVL3: 利用AI处理文本、图像、视频、OCR和数据分析
InternVL3推动了视觉-语言理解、推理和感知的边界。 在其前身InternVL 2.5的基础上,这个新版本引入了工具使用、GUI代理操作、3D视觉和工业图像分析方面的突破性能力。 让我们来分析一下是什么让InternVL3成为游戏规则的改变者 — 以及今天你如何开始尝试使用它。 InternVL…...
力扣刷题Day 48:盛最多水的容器(283)
1.题目描述 2.思路 学习了Krahets佬的双指针思路,初始化两个边界作为容器边界,然后逐个向数组内遍历,直到左右两指针相遇。 3.代码(Python3) class Solution:def maxArea(self, height: List[int]) -> int:left,…...
基于单应性矩阵变换的图像拼接融合
单应性矩阵变换 单应性矩阵是一个 3x3 的可逆矩阵,它描述了两个平面之间的投影变换关系。在图像领域,单应性矩阵可以将一幅图像中的点映射到另一幅图像中的对应点,前提是这两幅图像是从不同视角拍摄的同一平面场景。 常见的应用场景&#x…...
《驱动开发硬核特训 · 专题篇》:深入理解 I2C 子系统
关键词:i2c_adapter、i2c_client、i2c_driver、i2c-core、platform_driver、设备树匹配、驱动模型 本文目标:通过实际代码一步步讲清楚 I2C 子系统的结构与运行机制,让你不再混淆 platform_driver 与 i2c_driver 的职责。 🧩 一、…...
Spark缓存-cache
一、RDD持久化 1.什么时候该使用持久化(缓存) 2. RDD cache & persist 缓存 3. RDD CheckPoint 检查点 4. cache & persist & checkpoint 的特点和区别 特点 区别 二、cache & persist 的持久化级别及策略选择 Spark的几种持久化…...
tails os系统详解
一、起源与发展背景 1. 项目初衷与历史 创立时间:Tails 项目始于 2004 年,最初名为 “Anonymous Live CD”,2009 年正式更名为 “Tails”(The Amnesic Incognito Live System,“健忘的匿名实时系统”)。核…...
[洛谷刷题9]
P2376 [USACO09OCT] Allowance G(贪心) https://www.luogu.com.cn/problem/P2376 题目描述 作为创造产奶纪录的回报,Farmer John 决定开始每个星期给Bessie 一点零花钱。 FJ 有一些硬币,一共有 N ( 1 ≤ N ≤ 20 ) N (1 \le …...
数据挖掘入门-二手车交易价格预测
一、二手车交易价格预测 1-1 项目背景 随着二手车市场的快速发展,二手车交易价格的预测成为了一个热门研究领域。精准的价格预测不仅能帮助买卖双方做出更明智的决策,还能促进市场的透明度和公平性。对于买家来说,了解合理的市场价格可以避免…...
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】金融风控分析案例-10.4 模型部署与定期评估
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 10.4 模型部署与定期评估10.4.1 模型部署架构设计1.1 模型存储方案1.2 实时预测接口 10.4.2 定期评估体系构建2.1 评估指标体系2.2 自动化评估流程2.3 模型衰退预警 10.4.3 …...
构建可信数据空间需要突破技术、规则和生态三大关键
构建可信数据空间需要突破技术、规则和生态三大关键:技术上要解决"可用不可见"的隐私计算难题,规则上要建立动态确权和跨境流动的治理框架,生态上要形成多方协同的标准体系。他强调,只有实现技术可控、规则可信、生态协…...
阳光学院【2020下】计算机网络原理-A卷-试卷-期末考试试卷
一、单选题(共25分,每空1分) 1.ICMP协议工作在TCP/IP参考模型的 ( ) A.主机-网络 B.网络互联层 C.传输层 D.应用层 2.下列关于交换技术的说法中,错误的是 ( ) A.电路交换适用于突发式通信 B.报文交换不能满足实时通信 C.报文…...
python: union()函数用法
在 Python 中,union() 是集合(set)类型的内置方法,用于返回两个或多个集合的并集(即所有元素的合集,自动去重)。以下是它的用法详解: 1. 基本语法 python 复制 下载 set.union(*…...
docker部署WeDataSphere开源大数据平台
GitHub:https://github.com/WeBankFinTech/WeDataSphere **WDS容器化版本是由Docker构建的一个能够让用户在半小时内完成所有组件安装部署并使用的镜像包。**无需再去部署Hadoop等基础组件,也不需要部署WDS的各功能组件,即可让您快速体验 WD…...
【计算机视觉】OpenCV项目实战:基于face_recognition库的实时人脸识别系统深度解析
基于face_recognition库的实时人脸识别系统深度解析 1. 项目概述2. 技术原理与算法设计2.1 人脸检测模块2.2 特征编码2.3 相似度计算 3. 实战部署指南3.1 环境配置3.2 数据准备3.3 实时识别流程 4. 常见问题与解决方案4.1 dlib安装失败4.2 人脸检测性能差4.3 误识别率高 5. 关键…...
uni-app学习笔记五-vue3响应式基础
一.使用ref定义响应式变量 在组合式 API 中,推荐使用 ref() 函数来声明响应式状态,ref() 接收参数,并将其包裹在一个带有 .value 属性的 ref 对象中返回 示例代码: <template> <view>{{ num1 }}</view><vi…...
阿克曼-幻宇机器人系列教程2- 机器人交互实践(Topic)
在上一篇文章中,我们介绍了两种登录机器人的方式,接下来我们介绍登录机器人之后,我们如何通过topic操作命令实现与机器人的交互。 1. 启动 & 获取topic 在一个终端登录树莓派后,执行下列命令运行机器人 roslaunch huanyu_r…...
Windows系统事件查看器管理单元不可用
报错:Windows系统事件查看器管理单元不可用 现象原因:为误触关闭管理单元或者该模块卡死 解决办法:重启Windows server服务,若不行,则重启服务器即可...
milvus+flask山寨《从零构建向量数据库》第7章case2
继续流水账完这本书,这个案例是打造文字形式的个人知识库雏形。 create_context_db: # Milvus Setup Arguments COLLECTION_NAME text_content_search DIMENSION 2048 MILVUS_HOST "localhost" MILVUS_PORT "19530"# Inference Arguments…...
前端如何应对精确数字运算?用BigNumber.js解决JavaScript原生Number类型在处理大数或高精度计算时的局限性
目录 前端如何应对精确数字运算?用BigNumber.js解决JavaScript原生Number类型在处理大数或高精度计算时的局限性 一、BigNumber.js介绍 1、什么是 BigNumber.js? 2、作用领域 3、核心特性 二、安装配置与基础用法 1、引入 BigNumber.js 2、配置 …...
多目应用:三目相机在汽车智能驾驶领域的应用与技术创新
随着汽车智能驾驶技术不断完善,智能汽车也不断加速向全民普惠迈进,其中智驾“眼睛”三目视觉方案凭借低成本、高精度、强适配性成为众多汽车品牌关注的焦点。三目相机在汽车智能驾驶领域的创新应用,主要依托其多视角覆盖、高动态范围…...
webpack重构优化
好的,以下是一个关于如何通过重构 Webpack 构建策略来优化性能的示例。这个过程包括分析现有构建策略的问题、优化策略的制定以及具体的代码实现。 --- ### 项目背景 在参与公司的性能专项优化过程中,我发现现有的 Webpack 构建策略存在一些问题&#…...
MySQL 8.0 OCP(1Z0-908)英文题库(31-40)
目录 第31题题目分析正确答案 第32题题目分析正确答案 第33题题目分析正确答案: 第34题题目解析正确答案 第35题题目分析正确答案 第36题题目分析正确答案 第37题题目分析正确答案 第38题题目分析正确答案 第39题题目分析正确答案 第40题题目分析正确答案 第31题 Y…...
aardio - 虚表 —— vlistEx.listbar2 多层菜单演示
在 近我者赤 修改版的基础上,做了些许优化。 请升级到最新版本。 import win.ui; import godking.vlistEx.listbar2; import fonts.fontAwesome; /*DSG{{*/ mainForm win.form(text"多层折叠菜单";right1233;bottom713) mainForm.add({ custom{cls"…...
22.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--增加公共代码
在拆分服务之前,我们需要先提取一些公共代码。本篇将重点新增日志记录、异常处理以及Redis的通用代码。这些组件将被整合到一个共享类库中,便于在微服务架构中高效复用。 Tip:在后续的教程中我们会穿插多篇提取公共代码的文章,帮助…...
EasyOps®5月热力焕新:三大核心模块重构效能边界
在应用系统管理中,我们将管理对象从「服务实例」优化为「部署实例」,这一改变旨在提升管理效率与数据展示清晰度。 此前,系统以 “IP Port” 组合定义服务实例。当同一 IP 下启用多个进程或端口时,会产生多个服务实例。比如一台…...
基于深度学习的工业OCR数字识别系统架构解析
一、项目场景 春晖数字识别视觉检测系统专注于工业自动化生产监控、设备运行数据记录等关键领域。系统通过高精度OCR算法,能够实时识别设备上显示的关键数据(如温度、压力、计数等),并定时存储至Excel文件中。这些数据对于生产过…...