最近我不得不处理我的数据库提供程序的一些限制,它不支持表重命名。所以我不得不手动复制一个表。
我的 SaaS 平台的数据库托管在 Planetscale 上。该公司提供兼容 MySQL 的无服务器数据库。由于其无服务器特性,您可以获得水平分片、非阻塞模式更改以及许多更强大的数据库功能的强大功能,而无需实施它们。以及出色的开发人员体验。
从另一个角度来看,您必须处理有关架构更改的一些约束。需要这些限制来保证分片环境中的一致性。
自从我成为客户(大约两年前)以来,他们取得了很大的进步,例如对外键约束的支持:https://planetscale.com/docs/concepts/foreign-key-constraints
Inspector 是一个 Laravel 应用程序。使用 Laravel 迁移,我可以使用重命名函数来简单地更改表的名称:
Schema::rename('from', 'to');
Planetscale 本身不支持表重命名。所以我必须找到一种解决方法来完成任务。
老实说,重命名表是一个相当罕见的操作。对我来说,这是因为“项目”和“应用程序”实体之间的名称重叠。我必须重命名项目 - >应用程序。
MySQL中有两种复制表的方法。
您可以仅复制没有数据的表结构(列、键、索引等),使用 CREATE TABLE … LIKE:
CREATE TABLE applications LIKE projects;
结果是创建了与原始项目表结构完全相同的应用程序表,但没有数据。
要导入数据,您可以运行第二条语句 INSERT INTO … SELECT:
INSERT INTO applications SELECT * FROM projects;
在大表上运行此语句时要小心,因为它可能会占用大量时间和服务器资源。
第二个选项是仅复制列定义并使用 CREATE TABLE … AS SELECT:
在一条语句中导入数据
CREATE TABLE applications AS SELECT * FROM projects;
新的应用程序表仅继承项目表的基本列定义。它不重复外键约束、索引和自动增量定义。
当您拥有与表名称相关的索引名称和键名称时,此选项可能很有用。更改表的名称必须替换约束的名称。你最好根本不要导入它们并重新进行。
数据库始终是任何阶段开发者的热门话题。您可以在博客上找到其他技术资源。以下是有关该主题的最受欢迎的文章:
Inspector是专门为软件开发人员设计的代码执行监控工具。您无需在服务器级别安装任何内容,只需安装 composer 软件包 即可开始使用。
与其他复杂的一体化平台不同,Inspector 非常简单,并且对 PHP 友好。您可以尝试我们的 Laravel 或 Symfony 包。
如果您正在寻找有效的自动化、深入的见解以及将警报和通知转发到您的消息传递环境的能力,请免费尝试 Inspector。注册您的帐户。
或者在网站上了解更多信息:https://inspector.dev
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3