优秀数据库模式迁移工具的发展历程

news2025/1/15 16:48:27

数据库模式迁移可能是应用程序开发中风险最大的领域——因为这是一个困难的、有风险的和痛苦的过程。数据库模式迁移工具的存在是为了减轻这种痛苦,并且已经取得了长足的进步:从基本的CLI工具到GUI工具,从简单的SQL GUI客户端到一体化协作数据库平台。

命令行客户端(CLI) - MySQL/PSQL

MySQL和PSQL分别是MySQL和PostgreSQL的本地CLI,可以从命令行直接向MySQL或PostgreSQL服务器发送命令或查询。

尽管CLI界面很简单,但有时它会让初学者望而生畏。然而,根据Timescale公司的2022年PostgreSQL状态调查结果,PSQL是最受欢迎的与PostgreSQL交互的工具,超过了pgAdmin和DBeaver等GUI工具。

GUI

1.PHPMyAdmin和PGAdmin

PHPMyAdmin和PGAdmin是经典的SQL客户端。PHPMyAdmin已经是一个管理MySQL和MySQL兼容数据库(例如MariaDB)的工具,而PGAdmin是PostgreSQL的对应工具,现在已经发展到PGAdmin 4。与CLI工具相比,PHPMyAdmin和PGAdmin提供了一个用于运行和执行SQL查询的用户界面(UI),使它们更加友好。

2.DBeaver

DBeaver的最初版本发布于2010年,这款开源SQL客户端支持各种数据库(SQL、NoSQL和云数据库),并通过整合OpenAI公司的GPT功能跟上人工智能领域的最新趋势,允许将自然语言转换为SQL。

3.Navicat

Navicat于2001年首次发布。它当时只支持MySQL,但后来增加了更多的数据库。虽然Navicat的UI看起来有点过时,但它具有完整的功能,并且在操作数据库时提供了流畅的整体体验。

基于GUI的SQL客户端是对基于CLI的SQL客户端的良好补充。从根本上讲,它们的工作方式是一样的。用户可以快速方便连接到数据库并执行一些SQL。另一方面,在数据库更改管理和数据安全方面缺乏控制。本文将以Navicat为例进行详细介绍。

Gitops /数据库即代码

为了更好地管理和控制数据库模式更改,一些工具在数据库更改中引入了代码更改过程,称为数据库即代码(Database-as-Code)。

1.Liquibase

Liquibase创建于2006年,是一个用于跟踪、管理和应用数据库更改的开源库。一个有趣的事实是:Liquibase于2012年被一家名为Datical的公司收购,并更名为Datica,但随后于2020年更名为Liquibase(这是明智之举,见过有人在论坛上提到过Datica吗?)。

Liquibase的主要产品是基于Java的CLI,它允许开发团队通过CLI将数据库模式迁移集成到他们的CI/CD工作流中。

2.Flyway

Flyway与Liquibase在很多方面有相似之处:它们都是成立时间较长的数据库,拥有客户群,而且都是开源项目。它的核心产品是CLI和Java库。

Flyway背后的商业实体是Redgate(于2019年被收购)。它有3个版本:社区、团队和企业。可以看出,他们在开源和商业产品之间划出了一条清晰的界限:Flyway的网站总体上感觉更随意,而Redgate的方式更专业。

Liquibase和Flyway并驾齐驱。两者的主要区别在于各自的定位:Liquibase更面向企业,而Flyway更面向开发者。

3.Sqitch

Sqitch是一个纯开源项目,自从2012年以来一直没有商业产品上市。它是纯粹的CLI,没有UI。

与基于Java的Liquibase和Flyway不同,Sqitch是使用Perl开发的。此外,Sqitch在如何管理数据库模式更改方面有自己的理念:Liquibase和Flyway都使用文件命名约定来安排模式迁移(约定高于配置)。

而Sqitch采用了一种显式的方法,允许用户在Sqitch计划中指定顺序。

4.Atlas

Atlas是一个由Ariga构建的开源工具,并推广了“数据库模式即代码”这一术语。

可以看出,他们从HashiCorp那里获得了很多灵感,并在首次出现在Hacker News上时将自己称为“数据库迁移的Terraform”。他们还发明了基于HCL (HashiCorp配置语言)的Atlas HCL。

Atlas使用现代编程语言Go(与使用Java的Liquibase/Fireway不同),并以CLI为中心(类似于Liquibase.Fireay/Sqitch),但它也有一个轻量级的UI。Atlas Cloud是一个开源版本的商业产品。

一体化:GUI + Gitops / Database-As-Code + Collaboration

1.Prisma

像Prisma这样的ORM针对的是代码如何与数据交互的领域。虽然这更多的是一个后端主题,但Prisma是一个具有前端根的ORM。前端工程师可能不是最精通SQL的。为了降低管理数据库模式的障碍,Prisma发明了它的DSL来定义数据模型。

DSL是基于状态的(声明性的),它描述了数据库模式的最终状态,而不是增量变化,这与Liquibase/Flyway/Sqitch不同。通过这种方式,Prisma可以在整个应用程序开发周期中提供更全面的数据库管理视图。

Prisma ORM是开源的,可以免费使用,他们的数据平台提供了一个基于云的协作平台,具有一些高级功能(很明显,他们的目标不仅仅是一个ORM和模式迁移工具)。

2.Bytebase

Bytebase是一个开源数据库DevOps工具,涵盖了数据库管理场景,从变更、查询、安全性到基于Web的可视化协作工作区的治理。

Bytebase提供了一个基于Web的UI,开发人员和DBA可以通过同一个界面协作处理数据库更改。

3.数据库即代码(Database-As-Code)

为了更好地适应开发人员的工作习惯,Bytebase已经将功能集成到代码库中,例如itLab和GitHub。通过启用GitOps工作流,开发人员可以将数据库更改文件提交到熟悉的代码存储库,一旦审查完成并提交到repo, Bytebase将自动触发部署。无需在多个工具之间切换。

4.团队协作与管理

用户可以为两个级别的成员定义不同的角色:工作区和项目。可以为团队成员分配不同的角色,以便他们对不同的项目具有不同的权限;或者为每个项目配置审批工作流,例如指定负责此特定项目的特定DBA或QA。

Prisma和Bytebase的区别在于目标受众。Prisma主要针对前端/全栈开发人员,而Bytebase更专注于后端和DBA。这两款产品都提供协作功能,Prisma专注于单个项目中开发人员之间的协作,而Bytebase针对整个工程组织,即开发人员和DBA/平台工程/运营团队。

结语

如果用户以个人身份操作数据库,那么传统的CLI或GUI SQL客户端(如Navicat)就足够了。如果更喜欢与代码库集成,有像Liquebase和Flyway这样的解决方案。然而,对于类似Jira或GitLab的GUI和项目协作功能,可以选择Prisma和Bytebase。Bytebase是唯一一个提供组织范围管理功能的工具,除了使数据库更改更高效和更安全之外,还可以确保数据安全和治理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1115225.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[牛客]计算机网络习题笔记_1020

1、物理层:以太网 调制解调器 电力线通信(PLC) SONET/SDH G.709 光导纤维 同轴电缆 双绞线等。 2、数据链路层(网络接口层包括物理层和数据链路层):Wi-Fi(IEEE 802.11) WiMAX(IEEE 802.16) ATM DTM 令牌环 以太网 FDD…

在JavaScript中,如何创建一个数组或对象?

在JavaScript中,可以使用以下方式创建数组和对象: 一:创建数组(Array): 1:使用数组字面量(Array Literal)语法,使用方括号 [] 包裹元素,并用逗号分隔: let array1 = []; // 空数组 let array2 = [1, 2, 3]; // 包含三个数字的数组 let array3 = [apple, banana,…

HypeX Labs:充分释放加密资产的潜力

加密货币通常被视为是资产类别或投资工具,不过其代表了一种全新的意识形态,且与传统资产有着完全不同的底层价值逻辑,所以它们不仅可以被视为一种资产类别或投资工具,在大多数情况下可以被视为一种基于技术的实现。因此我们可以认…

C++练习:人员信息管理程序计算不同职员的每月工资。

要求编写一个简单的人员信息管理程序,具体要求如下: 程序涉及到五个类,分别是employee,technician,salesman,manager,salsemanager。 这五个类的关系为:employee是顶层父类&#xf…

AUTOSAR AP 硬核知识点梳理(3)AUTOSAR AP 方法论和开发流程的最佳实践

一 Adaptive AUTOSAR 方法论 AUTOSAR AP开发方法论包括三个主要阶段,分别是: 1、架构和设计阶段: 在这个阶段,您需要确定系统的需求、功能和服务,并将它们分配到合适的Machine上。 根据个人习惯使用一些建模工具,例如[Simulink]、[ProVision]或[RTA-VRTE SDK]自带的DS…

我们不一样①

我们不一样① 从hello world开始 别人的hello world​​ 我们的hello world 代码展示 #include <stdio.h> int main(){printf("\033[31mhello world\033[0m"); getchar();return 0; } 此处用了 ANSI转义序列 ANSI转义序列是一种带内信号的转义序列标准&am…

代码随想录算法训练营第23期day27|93.复原IP地址、78.子集、90.子集II

目录 一、&#xff08;leetcode 93&#xff09;复原IP地址 二、&#xff08;leetcode 78&#xff09;子集 三、&#xff08;leetcode 90&#xff09;子集II 一、&#xff08;leetcode 93&#xff09;复原IP地址 力扣题目链接 状态&#xff1a;没有写出来&#xff0c;待回顾…

Python —— 验证码的处理执行JavaScript语句

1、验证码的处理 1、概述&绕过验证码的方案 很多的网站都在登录页面加入了识别文字&#xff0c;识别图片&#xff0c;拖动拼图的验证码方式来防止爬虫、恶意注册 等&#xff0c;如果是做自动化&#xff0c;需要绕过验证码才能进入下一步操作&#xff0c;那么有4种方案可以…

深入探讨 Golang 中的追加操作

通过实际示例探索 Golang 中的追加操作 简介 在 Golang 编程领域&#xff0c;append 操作是一种多才多艺的工具&#xff0c;使开发人员能够动态扩展切片、数组、文件和字符串。在这篇正式的博客文章中&#xff0c;我们将踏上一段旅程&#xff0c;深入探讨在 Golang 中进行追加…

基于跳蛛优化的BP神经网络(分类应用) - 附代码

基于跳蛛优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于跳蛛优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.跳蛛优化BP神经网络3.1 BP神经网络参数设置3.2 跳蛛算法应用 4.测试结果&#xff1a;5.M…

eltable el-tooltip__popper 换行、字体、颜色等调整

show-overflow-tooltip属性 element-ui表格 默认情况下若内容过多会折行显示&#xff0c;若需要单行显示可以使用show-overflow-tooltip属性&#xff0c;它接受一个Boolean&#xff0c;为true时多余的内容会在 hover 时以 tooltip 的形式显示出来。 默认情况 element-ui表格 sh…

【练习题】二.栈和队列

1.蒋编号为0和[的两个栈存放于一个数组空间 V[m]中,栈底分别处于数组的两端。当第0号栈的栈顶播针 top[0]等F-1 时该戍为空:当第1号栈的栈顶指针 top[I]等于 m 时,该栈为空两个栈均从两端向中间增长 (见图 3.2)。试编写双栈初始化,判渐栈空、栈满、进栈和出栈等算法的两数。…

5年经验之谈 —— 总结自动化测试与性能测试的区别!

很多刚刚接触自动化测试和性能测试的同学感觉性能测试和自动化测试是没什么区别的&#xff0c;就像小编刚刚接触自动化测试和性能测试的时候一样&#xff0c;区别就是&#xff1a;自动化测试是一个用户在测试&#xff0c;而性能测试需要并发&#xff0c;需要设计各种场景。测试…

论文辅助笔记:t2vec 数据预处理

1 波尔图数据 curl http://archive.ics.uci.edu/ml/machine-learning-databases/00339/train.csv.zip -o data/porto.csv.zip 这条命令使用 curl 从给定的URL下载一个名为 train.csv.zip 的压缩文件&#xff0c;并将其保存为 data/porto.csv.zip。 unzip data/porto.csv.zip 使…

python实现矩阵转置

使用列表推导式实现矩阵转置 matrix [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]] print([[row[i] for row in matrix]for i in range(4)])使用内置函数来实现矩阵转置 matrix [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12]] print(list(map(list, zip(*matrix))))使用…

softplc windows 安装测试

下载 .NET 6.0 (Linux、macOS 和 Windows) 安装后 在这里 The command could not be loaded, possibly because: * You intended to execute a .NET application: The application restore does not exist. * You intended to execute a .NET SDK command: No…

如何利用IP定位技术进行反欺诈?

网络欺诈风险是指在互联网和数字领域中&#xff0c;存在各种类型的欺诈活动&#xff0c;旨在欺骗个人、组织或系统以获得非法获益。以下是一些常见的网络欺诈风险类型&#xff1a; 身份盗用&#xff1a;这是一种欺诈行为&#xff0c;涉及盗取他人的个人身份信息&#xff0c;如姓…

基于Java的汽车维修预约管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09; 代码参考数据库参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&am…

电度表和电能表是一样的吗?

电度表和电能表都是用于测量电能的仪表&#xff0c;但它们之间存在一些区别。接下来&#xff0c;小编来为大家介绍下电度表和电能表的区别有哪些吧&#xff0c;一起来看下&#xff01; 电度表是传统的机械式电能表&#xff0c;它通过测量电流和电压的乘积来计算电能&#xff0c…

数字化营销系统的重点功能?利用数字化营销系统为企业降本增效?

如今&#xff0c;越来越多的企业开始关注数字化营销&#xff0c;并利用数字化手段推动新的营销方式、模式和策划。数字化营销的重要性不言而喻&#xff0c;下面我们来了解一下数字化营销的优势有哪些&#xff1f; 1. 数字化营销可以更大程度地为用户提供足够的信息。 通过商品…