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

数据库中的数组: MySQL与StarRocks的数组操作解析

在现代数据处理中, 数组 (Array) 作为一种高效存储和操作结构化数据的方式, 被广泛应用于日志分析, 用户行为统计, 标签系统等场景. 然而, 不同数据库对数组的支持差异显著. 本文将以MySQLStarRocks为例, 深入解析它们的数组操作能力, 并对比其适用场景.

文章目录

    • 一 为什么需要数组操作?
    • 二 MySQL: 基于JSON数组的曲线救国
      • 1. 创建与初始化
      • 2. 修改与更新
      • 3. 查询与搜索
      • 4. 性能优化技巧
    • 三 StarRocks: 原生数组的高性能实践
      • 1. 原生数组的优势
      • 2. 核心操作示例
    • 四 如何选择?MySQL vs StarRocks对比
    • 五 实战建议

一 为什么需要数组操作?

数组能够将多个相关值聚合为单个字段, 例如:

  • 用户标签: ["科技爱好者", "程序员", "健身达人"]
  • 订单商品ID列表: [1001, 1003, 1005]
  • 时序数据: [25.3, 24.8, 26.1]

传统关系型数据库 (如MySQL) 通常依赖多表关联处理这类需求, 而现代分析型数据库 (如StarRocks) 通过原生数组类型和丰富的函数, 大幅提升了数据操作的效率. 接下来, 我们将分别探讨两者的实现方式.


二 MySQL: 基于JSON数组的曲线救国

MySQL虽不支持原生数组类型, 但从5.7版本起引入了JSON类型, 通过JSON数组模拟数组操作, 适合轻量级场景.

1. 创建与初始化

  • JSON_ARRAY(): 快速构造JSON数组

    -- 创建包含混合类型的数组
    SELECT JSON_ARRAY('手机', 2999, TRUE); 
    -- 输出: ["手机", 2999, true]
    
  • JSON_ARRAYAGG(): 聚合多行数据为数组

    -- 将用户订单的商品ID聚合为数组
    SELECT user_id, JSON_ARRAYAGG(product_id) 
    FROM orders GROUP BY user_id;
    

2. 修改与更新

  • JSON_INSERT(): 在指定位置插入元素

    SET @cart = '["笔记本", "钢笔"]';
    SELECT JSON_INSERT(@cart, '$[2]', '橡皮'); 
    -- 输出: ["笔记本", "钢笔", "橡皮"]
    
  • JSON_REMOVE(): 删除指定索引的元素

    SELECT JSON_REMOVE('["A", "B", "C"]', '$[1]'); 
    -- 输出: ["A", "C"]
    

3. 查询与搜索

  • JSON_EXTRACT() (或->运算符) : 提取元素

    SELECT tags->'$[0]' FROM user_profile 
    WHERE id = 1001; -- 提取第一个标签
    
  • JSON_CONTAINS(): 判断是否包含特定值

    SELECT * FROM products 
    WHERE JSON_CONTAINS(category_ids, '1003');
    

4. 性能优化技巧

  • 多值索引 (Multi-Valued Indexes) : 加速JSON数组查询

    CREATE INDEX idx_tags ON users (CAST(profile->'$.tags' AS CHAR(255) ARRAY)
    );
    
  • JSON_TABLE(): 将数组转换为临时表进行JOIN操作

    SELECT user_id, tag 
    FROM users, JSON_TABLE(profile->'$.tags', '$[*]' COLUMNS (tag VARCHAR(50) PATH '$')
    ) AS tags;
    

三 StarRocks: 原生数组的高性能实践

StarRocks作为分析型数据库, 从2.5版本起支持原生数组类型 (ARRAY<T>) , 并针对大数据场景优化了性能, 适合复杂计算.

1. 原生数组的优势

  • 存储高效: 二进制编码, 比JSON解析速度更快.
  • 计算优化: 向量化执行引擎加速聚合, 过滤等操作.
  • 类型安全: 强制元素类型一致 (如ARRAY<INT>) .

2. 核心操作示例

  • 创建数组

    -- 直接构造数组
    SELECT ARRAY(1, 2, 3); -- 输出: [1, 2, 3]-- 从字符串转换
    SELECT CAST('[2023-01-01, 2023-01-02]' AS ARRAY<DATE>);
    
  • 动态修改

    -- 追加元素
    SELECT ARRAY_APPEND(scores, 95) FROM student;-- 删除所有匹配值
    SELECT ARRAY_REMOVE(ARRAY(1,2,2,3), 2); -- 输出: [1,3]
    
  • 高级分析

    -- 计算数组统计值
    SELECT ARRAY_SUM(daily_sales) FROM shop; -- 周销量总和-- 生成累加数组
    SELECT ARRAY_CUM_SUM(ARRAY(10, 20, 30)); -- 输出: [10, 30, 60]
    
  • 与Bitmap结合

    -- 用户兴趣标签的并集计算
    SELECT BITMAP_UNION(ARRAY_TO_BITMAP(tags)) 
    FROM user_interest;
    

四 如何选择?MySQL vs StarRocks对比

场景推荐方案原因
轻量级业务 (如CMS标签)MySQL JSON数组兼容性强, 无需改造表结构, 适合已有MySQL系统的扩展.
实时分析 (如用户画像)StarRocks原生数组原生类型性能更高, 支持复杂聚合 (如ARRAY_UNIQUE_AGG()) .
混合型数据操作MySQL多值索引 + JSON_TABLE()兼顾JSON灵活性和查询效率.
海量数据计算StarRocks数组 + 向量化引擎分布式架构和列式存储优化, 适合TB级数据分析.

五 实战建议

  1. MySQL适用场景

    • 数据结构变化频繁 (如动态表单字段) .
    • 需要兼容JSON API接口.
    • 示例: 电商订单的扩展属性存储.
  2. StarRocks适用场景

    • 固定模式的数组分析 (如时序数据, 用户行为序列) .
    • 需要高性能聚合计算 (如广告点击流分析) .
    • 示例: 分析用户最近30天的登录时间分布.

相关文章:

数据库中的数组: MySQL与StarRocks的数组操作解析

在现代数据处理中, 数组 (Array) 作为一种高效存储和操作结构化数据的方式, 被广泛应用于日志分析, 用户行为统计, 标签系统等场景. 然而, 不同数据库对数组的支持差异显著. 本文将以MySQL和StarRocks为例, 深入解析它们的数组操作能力, 并对比其适用场景. 文章目录 一 为什么需…...

Qt 交叉编译详细配置指南

一、Qt 交叉编译详细配置 1. 准备工作 1.1 安装交叉编译工具链 # 例如安装ARM工具链(Ubuntu/Debian) sudo apt-get install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf# 或者64位ARM sudo apt-get install gcc-aarch64-linux-gnu g++-aarch64-linux-gnu 1.2 准备目标…...

【详细图文】在VScode中配置python开发环境

目录 一、下载安装VSCode 1、官网下载VSCode 2、安装VSCode 3、汉化vscode &#xff08;1&#xff09;已自动下载汉化版插件 &#xff08;2&#xff09;未自动下载汉化版插件 二、 下载安装Python 1、官网下载Python 2、安装Python &#xff08;1&#xff09;双击打开…...

strings.Fields 使用详解

目录 1. 官方包 2. 支持版本 3. 官方说明 4. 作用 5. 实现原理 6. 推荐使用场景和不推荐使用场景 推荐场景 不推荐场景 7. 使用场景示例 示例1&#xff1a;官方示例 示例2&#xff1a;解析服务器日志 示例3&#xff1a;清理用户输入 8. 性能比较 性能特点 对比表…...

PCI认证 密钥注入 ECC算法工具 NID_secp521r1 国密算法 openssl 全套证书生成,从证书提取公私钥数组 x,y等

步骤 1.全套证书已经生成。OK 2.找国芯要ECC加密解密签名验签代码。给的逻辑说明没有示例代码很难的上。 3.集成到工具 与SP联调。 1.用openssl全套证书生成及验证 注意&#xff1a;这里CA 签发 KLD 证书用的是SHA256。因为芯片只支持SHA256算法,不支持SHA512。改成统一。…...

微软 SC-900 认证-考核Azure 和 Microsoft 365中的安全、合规和身份管理(SCI)概念

微软 SC-900 认证介绍 SC-900 认证考试是微软推出的一项基础级别认证&#xff0c;全称为 Microsoft Certified: Security, Compliance, and Identity Fundamentals。该认证旨在验证考生对微软云服务&#xff08;如 Azure 和 Microsoft 365&#xff09;中的安全、合规和身份管理…...

Uniapp 集成极光推送(JPush)完整指南

文章目录 前言一、准备工作1. 注册极光开发者账号2. 创建应用3. Uniapp项目准备 二、集成极光推送插件方法一&#xff1a;使用UniPush&#xff08;推荐&#xff09;方法二&#xff1a;手动集成极光推送SDK 三、配置原生平台参数四、核心功能实现1. 获取RegistrationID2. 设置别…...

OpenCV图像平滑处理方法详解

文章目录 引言一、什么是图像平滑&#xff1f;二、常见的图像平滑方法1.先对图片加上噪声点2. 均值滤波&#xff08;Averaging&#xff09;3. 方框滤波&#xff08;boxFilter&#xff09;4. 中值滤波&#xff08;Median Blur&#xff09;5. 高斯滤波&#xff08;Gaussian Blur&…...

Lua 中,`math.random` 的详细用法

在 Lua 中&#xff0c;math.random 是用于生成伪随机数的核心函数。以下是其详细用法、注意事项及常见问题的解决方案&#xff1a; Lua 中&#xff0c;math.random 的详细用法—目录 一、基础用法1. 生成随机浮点数&#xff08;0 ≤ x < 1&#xff09;2. 生成指定范围的随机…...

使用PX4,gazebo,mavros为旋翼添加下视的相机(仿真采集openrealm数据集-第一步)

目录 一.方法一&#xff08;没成功&#xff09; 1.运行PX4 2.运行mavros通讯 3.启动仿真世界和无人机 &#xff08;1&#xff09;单独测试相机 &#xff08;2&#xff09;make px4_sitl gazebo启动四旋翼iris无人机 二.方法二&#xff08;成功&#xff09; 1.通过 rosl…...

ATEngin开发记录_4_使用Premake5 自动化构建跨平台项目文件

该系列只做记录 不做教程 所以文章简洁直接 会列出碰到的问题和解决方案 只适合C萌新 文章目录 Permake5为什么使用 Premake&#xff1f; 项目实战总结一下&#xff1a;详细代码: Permake5 Premake5 是一个跨平台的构建配置工具&#xff0c;它允许开发者通过使用一个简单的脚…...

equals() 和 hashCode()

作为 Java 开发者&#xff0c;我们经常会用到 equals() 和 hashCode() 这两个方法。 它们是 Object 类中定义的基础方法&#xff0c;看似简单&#xff0c;但如果理解不透彻&#xff0c;很容易在实际开发中踩坑。 本文将深入探讨这两个方法的作用、区别、以及如何正确地重写它们…...

臭氧除菌柜市场报告:2031年全球臭氧除菌柜市场销售额预计将达到9.4亿元

一、市场概述 &#xff08;一&#xff09;定义与分类 臭氧除菌柜&#xff0c;作为新一代绿色消毒设备&#xff0c;主要利用臭氧&#xff08;O₃&#xff09;的强氧化性来实现无化学残留的消毒净化。根据产品类型&#xff0c;可分为单门型和双门型。单门型设计紧凑&#xff0c…...

解决python manage.py shell ModuleNotFoundError: No module named xxx

报错如下&#xff1a; python manage.py shellTraceback (most recent call last):File "/Users/z/Documents/project/c/manage.py", line 10, in <module>execute_from_command_line(sys.argv)File "/Users/z/.virtualenvs/c/lib/python3.12/site-packa…...

通用接口函数注册模块设计与实现

文章目录 通用接口函数注册模块设计与实现1. 模块概述2. 核心功能2.1 数据结构函数注册项结构体注册函数宏 2.2 核心函数实现函数&#xff1a;sl_register_interface_functions 3. 使用示例3.1 基础使用示例 - 设备驱动接口定义接口结构体实现具体函数创建注册表注册接口 3.2 高…...

C,C++,C#

C、C 和 C# 是三种不同的编程语言&#xff0c;虽然它们名称相似&#xff0c;但在设计目标、语法特性、运行环境和应用场景上有显著区别。以下是它们的核心区别&#xff1a; 1. 设计目标和历史 语言诞生时间设计目标特点C1972&#xff08;贝尔实验室&#xff09;面向过程&#…...

scala-集合3

集合计算高级函数 过滤&#xff1a;遍历一个集合并从中获取满足指定条件的元素组成一个新的集合 &#xff08;筛选出满足条件的元素组成新集合。&#xff09; 转换或映射&#xff08;map&#xff09;&#xff1a;将原始集合中的元素映射到某个函数。 扁平化&#xff1a;取消…...

Spring MVC 重定向(Redirect)详解

Spring MVC 重定向&#xff08;Redirect&#xff09;详解 1. 核心概念与作用 重定向&#xff08;Redirect&#xff09; 是 Spring MVC 中一种客户端重定向机制&#xff0c;通过 HTTP 302 状态码&#xff08;默认&#xff09;将用户浏览器重定向到指定 URL。 主要用途&#xf…...

Scala的集合(二)

1. 集合计算高集函数 任务要求 1)过滤:遍历一个集合并从中获取满足指定条件的元素组成一个新的集合 2)转化/映射&#xff08;map&#xff09;&#xff1a;将集合中的每一个元素映射到某一个函数 3)扁平化 4)扁平化映射 注&#xff1a;flatMap 相当于先进行 map 操作&#…...

GZ036区块链卷三 EtherGame合约漏洞详解

题目 pragma solidity ^0.8.3; contract EtherGame {uint public targetAmount 7 ether;address public winner;function deposit() public payable {require(msg.value 1 ether, "You can only send 1 Ether");uint balance address(this).balance;require(bala…...

BGP路由协议之路由通告/传递

BGP 的路由宣告 BGP 自身并不会发现并计算产生路由&#xff0c;只会将 IGP 路由表中的路由引入到 BGP 路由表中&#xff0c;并通过 Update 报文传递给 BGP 对等体&#xff08;邻居&#xff09; ​Network​ 宣告&#xff0c;前提是路由表中存在该条路由 ​import-route​ 引…...

Python合并多个pdf

场景&#xff1a; 现在要解决批量合并PDF的问题。 有很多PDF文件需要合并成一个&#xff0c;比如报告、发票或者多个章节的文档。 对于Windows用户&#xff0c;Adobe Acrobat是专业的选择&#xff0c;但需要付费。但是我不想花钱&#xff0c;所以推荐免费软件&#xff0c;比…...

聊一聊接口测试时遇到上下游依赖时该如何测试

目录 一、手工测试时的处理方法 1.1沟通协调法 1.2模拟数据法 二、自动化测试时的处理方法 2.1 数据关联法&#xff08;变量提取&#xff09; 2.2 Mock数据法 2.3自动化框架中的依赖管理 三、实施示例&#xff08;以订单接口测试为例&#xff09; 3.1Mock依赖接口&…...

pdf转latex

Doc2X&#xff08;https://doc2x.noedgeai.com/&#xff09; Doc2X 是一个由 NoEdgeAI 提供的在线工具&#xff0c;主要用于将 PDF 文件&#xff08;尤其是学术论文、报告等文档&#xff09;转换为 LaTeX 格式。LaTeX 是一种高质量排版系统&#xff0c;广泛应用于学术界和出版…...

剖析 Docker Swarm 操作对原有容器端口影响

剖析 Docker Swarm 操作对容器端口影响 一、背景阐述 在使用 Docker Swarm 构建集群环境过程中&#xff0c;于 ts3 节点出现了原有的容器端口全部失效&#xff0c;手动重启后才恢复的情况。期间涉及 docker swarm init --advertise-addr172.16.10.110 以及 docker swarm join…...

QML面试笔记--UI设计篇02布局控件

1. QML 中常用的布局控件 1.1. Row1.2. Column1.3. Grid1.4. RowLayout1.5. ColumnLayout1.6. GridLayout1.7. 总结 1. QML 中常用的布局控件 1.1. Row 背景知识&#xff1a;Row 布局用于将子元素水平排列&#xff0c;适合简单的线性布局&#xff0c;如工具栏按钮或表单输入…...

Java全栈项目--校园快递管理与配送系统(4)

源代码续 /*** 通知工具类*/// 通知类型常量 export const NotificationType {SYSTEM: 1,EXPRESS: 2,ACTIVITY: 3 }// 通知类型名称映射 export const NotificationTypeNames {[NotificationType.SYSTEM]: 系统通知,[NotificationType.EXPRESS]: 快递通知,[NotificationType…...

c语言练习一

1、统计二进制数中1的个数 #include <stdio.h>int main(void) {int count 0; //统计1出现次数 int x 0b1011;while(x){count ;//x 0b1011 > x-1 0b1010 x-1,将x从右往左数遇到第一个1变成0&#xff0c;左边全部变为1&#xff0c;右边不变 //x&x-1 1010 …...

Scala安装

Spark安装 Spark的Local模式仅需要单个虚拟机节点即可&#xff0c;无需启动hadoop集群。实验步骤如下&#xff1a; 将spark的安装包上传到虚拟机node01中&#xff08;建议路径&#xff1a;/opt/software/spark&#xff09;并解压缩文件。将解压文件夹重命名为spark-local 解…...

爱普生RTC模块RA8804CE在ADAS域控制器的应用

在汽车智能化、自动化飞速发展的时代&#xff0c;ADAS&#xff08;高级驾驶辅助系统&#xff09;的多传感器融合与实时决策高度依赖精准的时间基准。毫秒级的时间偏差可能导致传感器数据错位&#xff0c;直接影响行车安全。爱普生RA8804CE实时时钟模块凭借其内置的32.768 kHz晶…...

开箱即用!推荐一款Python开源项目:DashGo,支持定制改造为测试平台!

大家好&#xff0c;我是狂师。 市面上的开源后台管理系统项目层出不穷&#xff0c;对应所使用到的技术栈也不尽相同。 今天给大家推荐一款开源后台管理系统: DashGo&#xff0c;不仅部署起来非常的简单&#xff0c;而且它是基于Python技术栈实现的&#xff0c;使得基于它进行…...

C++使用WebView2控件,通过IPC通信与Javascript交互

引言 在现代桌面应用程序开发中&#xff0c;Web技术与原生应用的融合变得越来越普遍。Microsoft的WebView2控件为C开发者提供了一个强大的工具&#xff0c;使他们能够在桌面应用中嵌入基于Chromium的Web浏览器引擎。本文将详细介绍如何在C应用程序中使用WebView2控件&#xff…...

算法中Hash备胎——LRU的设计与实现

核心内容1.理解LRU的原理2.理解LRU是如何实现的3.能够通过代码实现LRU 缓存是应用软件的必备功能之一&#xff0c;在操作系统、Java里的Spring、mybatis、redis、mysql等软件中都有自己的内部缓存模块&#xff0c;而缓存是如何实现的&#xff1f; 在操作系统教科书里我们知道…...

Profinet邂逅ModbusRTU:印刷厂有网关“一键打通”通信链路

Profinet邂逅ModbusRTU&#xff1a;印刷厂有网关“一键打通”通信链路 在现代化印刷厂的生产线上&#xff0c;高效稳定的设备通信是保障印刷质量和生产效率的关键。某印刷厂的印刷机控制系统采用了西门子PLC进行自动化控制&#xff0c;同时还有众多基于ModbusRTU协议的传感器和…...

Spring中使用Kafka的详细配置,以及如何集成 KRaft 模式的 Kafka

在 Spring 中使用 Apache Kafka 的配置主要涉及 Spring Boot Starter for Kafka&#xff0c;而开启 ‌KRaft 模式‌&#xff08;Kafka 的元数据管理新模式&#xff0c;替代 ZooKeeper&#xff09;需要特定的 Kafka Broker 配置。以下是详细步骤&#xff1a; 一、Spring 中集成 …...

C++之继承

本节我们将要学习C作为面向对象语言的三大特性之一的继承。 前言 一、继承的概念 二、继承的定义 2.1 定义格式 2.2 继承基类成员访问方式的变化 2.3 继承类模板 三、基类和派生类之间的转换 四、继承中的作用域 五、派生类的默认成员函数 六、实现一个不能被继承的类 七、继承…...

服务器申请 SSL 证书注意事项

一、确认证书类型 基础域名型&#xff08;DV&#xff09;&#xff1a;这类证书验证速度最快&#xff0c;通常只需验证域名所有权&#xff0c;几分钟到几小时即可颁发。适用于个人博客、小型企业展示网站等对安全性要求不是顶级严苛&#xff0c;且急需启用 HTTPS 的场景。但它仅…...

【资料分享】全志T536(异构多核ARMCortex-A55+玄铁E907 RISC-V)工业核心板说明书

核心板简介 创龙科技SOM-TLT536是一款基于全志科技T536MX-CEN2/T536MX-CXX四核ARM Cortex-A55 +...

博途 TIA Portal之1200做从站与调试助手的TCP通讯

其实&#xff0c;1200做从站与调试助手做TCP通讯很简单&#xff0c;只需要在组态时把“主动建立连接”放在对侧即可。但是我们还是要从头讲起&#xff0c;以方便没有基础的朋友能直接上手操作。 1、硬件准备 1200PLC一台&#xff0c;带调试助手的PC机一台&#xff0c;调试助手…...

移动端六大语言速记:第9部分 - 并发与多线程

移动端六大语言速记:第9部分 - 并发与多线程 本文将对比Java、Kotlin、Flutter(Dart)、Python、ArkTS和Swift这六种移动端开发语言在并发与多线程方面的特性,帮助开发者理解和掌握各语言的并发编程机制。 9. 并发与多线程 9.1 线程与进程 各语言线程与进程的创建和管理方…...

基于大模型的ALS预测与手术优化系统技术方案

目录 技术方案文档:基于大模型的ALS预测与手术优化系统1. 数据预处理与特征工程模块流程图伪代码2. 多模态融合预测模型模型架构图伪代码3. 术中实时监测与动态干预系统系统流程图伪代码4. 统计验证与可解释性模块验证流程图伪代码示例(SHAP分析)5. 健康教育与交互系统系统架…...

【Vue3知识】组件间通信的方式

组件间通信的方式 概述**1. 父子组件通信****父组件向子组件传递数据&#xff08;Props&#xff09;****子组件向父组件发送事件&#xff08;自定义事件&#xff09;** **2. 兄弟组件通信****通过父组件中转****使用全局状态管理&#xff08;如 Pinia 或 Vuex&#xff09;** **…...

【数据挖掘】岭回归(Ridge Regression)和线性回归(Linear Regression)对比实验

这是一个非常实用的 岭回归&#xff08;Ridge Regression&#xff09;和线性回归&#xff08;Linear Regression&#xff09;对比实验&#xff0c;使用了 scikit-learn 中的 California Housing 数据集 来预测房价。 &#x1f4e6; 第一步&#xff1a;导入必要的库 import num…...

RuntimeError: Error(s) in loading state_dict for ChartParser

一 bug错误 最近使用千问大模型有一个bug&#xff0c;报错信息如下 raise RuntimeError(Error(s) in loading state_dict for {}:\n\t{}.format( RuntimeError: Error(s) in loading state_dict for ChartParser:Unexpected key(s) in state_dict: "pretrained_model.em…...

汽车无钥匙启动125KHz低频发射天线工作原理

汽车智能钥匙低频天线是无钥匙进入&#xff08;PE&#xff09;及无钥匙启动&#xff08;PS&#xff09;系统的一部分&#xff0c;主要负责发送低频信号&#xff0c;探测智能钥匙与各低频天线间的相对位置&#xff0c;判断车内是否存在智能钥匙。 支持PEPS系统实现便捷操作 无…...

【Docker基础-镜像】--查阅笔记2

目录 Docker镜像概述base镜像镜像的分层结构镜像的理解镜像的构建docker commit 制作镜像DockerfileDockerfile 指令FROMLABELRUNARGENVADDCOPYWORKDIRUSERVOLUMEEXPOSECMD 和 ENTRYPOINT Docker镜像概述 镜像是Docker容器的基石&#xff0c;容器是镜像的运行实例&#xff0c;…...

LeetCode 第47题:旋转数组

LeetCode 第47题&#xff1a;旋转数组 题目描述 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像&#xff0c;这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 示例1&#xff1a; 输入&#xf…...

数据库管理工具实战:IDEA 与 DBeaver 连接 TDengine(二)

五、DBeaver 连接 TDengine 实战 5.1 安装 DBeaver 下载安装包&#xff1a;访问 DBeaver 官方网站&#xff08;https://dbeaver.io/download/ &#xff09;&#xff0c;根据你的操作系统选择合适的安装包。如果是 Windows 系统&#xff0c;下载.exe 格式的安装文件&#xff1…...

4S店汽车维修保养管理系统 (源码+lw+部署文档+讲解),源码可白嫖!

摘要 二十一世纪我们的社会进入了信息时代&#xff0c;信息管理系统的建立&#xff0c;大大提高了人们信息化水平。传统的管理方式已经与当今4S店汽车维修保养管理系统的业务需求不相适应,也与4S店汽车维修保养管理系统化建设的发展趋势不相适应。本文针对这一需求设计并实现了…...

【Mysql】主从复制部署(保姆级)

本次部署用到三台Ubuntu虚拟机&#xff08;一主两从&#xff09;&#xff1a; Master服务器&#xff1a;192.168.166.107 Slave1服务器&#xff1a;192.168.166.101 Slave2服务器&#xff1a;192.168.166.103 一、部署思路 首先我们要先捋清主从复制的部署思路…...