phinx数据库脚本迁移工具

phinx数据库脚本迁移工具

Phinx 可以使用 Composer 进行安装,Composer是一个PHP依赖管理工具。更多信息请访问 Composer 官网。

Phinx 至少需要PHP 5.4 或更新的版本

第一步:安装

composer require robmorgan/phinx

第二步:初始化

安装后,Phinx 现在可以在你的项目中执行初始化

php vendor/robmorgan/phinx/bin/phinx init

第三步:配置文件

phinx.yml

第四步:创建迁移 文件名驼峰命名

php vendor/robmorgan/phinx/bin/phinx create MyNewMigration

这里写图片描述

这将创建一个新的迁移脚本,格式是 YYYYMMDDHHMMSS_my_new_migration.php ,前14个字符是当前的timestamp,精确到秒。
这里写图片描述
如果你指定了多个脚本路径,将会提示你选择哪一个。

Phinx 自动创建的迁移脚本框架有一个方法:

<?php

use Phinx\Migration\AbstractMigration;

class MyNewMigration extends AbstractMigration
{
    /**
     * Change Method.
     *
     * Write your reversible migrations using this method.
     *
     * More information on writing migrations is available here:
     * http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
     *
     * The following commands can be used in this method and Phinx will
     * automatically reverse them when rolling back:
     *
     *    createTable
     *    renameTable
     *    addColumn
     *    renameColumn
     *    addIndex
     *    addForeignKey
     *
     * Remember to call "create()" or "update()" and NOT "save()" when working
     * with the Table class.
     */
    public function change()
    {
       //添加qaSource字段(qa来源)
        $wbrqa = $this->table("wbrqa");
        if (!$wbrqa->hasColumn('qaSource')) {
            $wbrqa->addColumn("qaSource", "string", ['limit' => 30, 'null' => true, 'default' => '', 'comment' => 'qa来源'])->update();
        }
    }
        //更改列属性[wbrqa: qid、aid更改字段属性为varchar 用户于存储mongoDb: _id、parentId]
        $wbrqa = $this->table("wbrqa");
        $wbrqa->changeColumn('qId', 'string', ['limit' => 255, 'null' => true])->save();
        $wbrqa->changeColumn('aId', 'string', ['limit' => 255, 'null' => true])->save();
        $wbrqa->changeColumn('qUserId', 'string', ['limit' => 255, 'null' => true])->save();

       $wbrqa = $this->table("wbrqa");
        if (!$wbrqa->hasColumn('isDeleted')) {
            $wbrqa->addColumn("isDeleted", "integer", ['limit' => 2, 'null' => true,                          'default' => '0', 'comment' => '是否删除'])->update();
        }
        //建立索引
        $wbrqa->hasIndex(['isDeleted', 'index_wbrqa_isDeleted']);
}

第五步:执行脚本

php vendor/robmorgan/phinx/bin/phinx migrate -e localhost

注意点:


> php vendor/robmorgan/phinx/bin/phinx migrate -e *localhost*

此处的localhost为你本地的环境,也可以是线上环境,但是在使用之前,必须配好环境。
环境配置在下一文章详细说明。
链接地址:https://blog.csdn.net/weixin_39690767/article/details/80267801

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL数据库脚本转PgSQL数据库脚本工具是一种用于将使用MySQL语法编写的数据库脚本转换为使用PgSQL语法编写的数据库脚本工具。这样可以在不用手动修改代码的情况下,轻松地将MySQL数据库迁移到PgSQL数据库。 使用这样的工具可以带来一些优势。首先,它可以节省时间和精力,因为手动将MySQL脚本转换为PgSQL脚本可能会非常繁琐。工具可以自动识别并转换查询语句、表定义、索引和其他数据库对象。 其次,使用这种工具可以减少人为错误的发生。手动转换脚本意味着有可能出现疏漏或错误的转换,导致数据库迁移过程中出现问题。使用工具可以提高准确性和可靠性,减少潜在错误的出现。 此外,这种工具通常还提供了一些额外的功能,例如自动检测并解决不兼容的语法、数据类型或函数等。这样的功能可以进一步简化迁移过程,并确保转换后的脚本可以成功地在PgSQL数据库中运行。 总之,MySQL数据库脚本转PgSQL数据库脚本工具是一种有用的工具,可以帮助开发人员轻松地将MySQL数据库迁移到PgSQL数据库。它能够节省时间和精力,并保证准确性和可靠性。对于需要进行数据库迁移的项目来说,这是一个十分方便的工具。 ### 回答2: MySQL数据库脚本转PGSQL数据库脚本工具是一种实用工具,可以将MySQL数据库脚本转换成PGSQL数据库脚本。MySQL和PGSQL是两种不同的关系型数据库管理系统,它们在语法和功能上存在一些差异。当需要将MySQL数据库迁移到PGSQL数据库时,如果手动修改脚本将会非常繁琐和耗时,这时就需要使用MySQL数据库脚本转PGSQL数据库脚本工具。 该工具可以从MySQL数据库中提取脚本,并将其转换成与PGSQL数据库兼容的格式。它能够将MySQL的特定语法和功能转换成PGSQL数据库可以理解和执行的语法和功能。这样,我们就可以简单方便地将MySQL数据库迁移到PGSQL数据库,而无需手动修改每个脚本。 此工具通常具有用户友好的界面和简单易用的操作步骤。用户只需导入MySQL脚本文件,选择要转换成PGSQL格式的文件和转换选项,然后点击转换按钮即可。工具会自动将MySQL脚本转换成PGSQL脚本,并输出转换后的文件供用户使用。 除了将MySQL脚本转换成PGSQL脚本,该工具通常还提供其他功能,如批量转换和批量执行脚本等。这些功能使用户能够更高效地迁移管理数据库。 综上所述,MySQL数据库脚本转PGSQL数据库脚本工具是一种便捷实用的工具,可以将MySQL数据库脚本转换成PGSQL数据库脚本,从而简化数据库迁移过程,并提高数据库管理的效率。 ### 回答3: MySQL数据库脚本转换为PgSQL数据库脚本工具有很多,其中一种常用的工具是pgloader。pgloader是一个用于将数据从其他数据库系统(包括MySQL)迁移到PostgreSQL的开源工具。 使用pgloader工具可以方便地将MySQL数据库脚本转换为PgSQL数据库脚本。以下是使用pgloader进行转换的步骤: 1. 安装pgloader工具:将pgloader的安装文件下载到本地,然后通过命令行或终端安装。 2. 创建目标数据库:在PostgreSQL中创建一个用于存储转换后数据的目标数据库。 3. 创建一个MySQL连接的配置文件:在本地创建一个配置文件,包含要连接的MySQL数据库的相关信息,如主机名、端口、用户名和密码等。 4. 创建一个PgSQL连接的配置文件:同样,在本地创建一个配置文件,包含要连接的PgSQL数据库的相关信息,如主机名、端口、用户名和密码等。 5. 编写转换脚本:使用pgloader提供的脚本语法,将MySQL数据库脚本转换为PgSQL数据库脚本。根据需要可以选择将表、视图、函数、存储过程等转换到PgSQL数据库。 6. 运行pgloader工具:通过命令行或终端运行pgloader工具,指定MySQL和PgSQL连接的配置文件和转换脚本。 7. 检查转换结果:在转换过程完成后,检查PgSQL数据库中的数据是否正确转换。 通过使用pgloader工具,可以快速、简便地将MySQL数据库脚本转换为PgSQL数据库脚本。除了pgloader,还有其他一些类似的工具可供选择,如mysqldump转pg_dump或使用ETL工具进行转换等。根据具体需求选择合适的工具可以提高转换效率和准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值