教你使用PHP資料庫遷移工具「Phinx」

2022-02-17 13:00:49
本篇文章給大家分享關於處理中資料庫遷移工具Phinx的相關知識,phinx特別適合在開發、測試、線上資料庫同步欄位資訊、資料資訊、生成和同步測試資料等,希望對大家有幫助。

檔案地址:https://tsy12321.gitbooks.io/phinx-doc/content

1.安裝

composer require nhzex/think-phinx

2.執行

php vendor/bin/phinx

直接執行 php vendor/bin/phinx init 可生成組態檔

另外一種方法是直接使用php檔案做組態檔

直接執行 php vendor/bin/phinx init 可生成組態檔

另外一種方法是直接使用php檔案做組態檔

3.使用phinx.php進行設定

<?php
$config = array(
    'DB_HOST' => 'localhost',
    'DB_NAME' => 'root',
    'DB_USER' => 'root',
    'DB_PWD' => '',
);
$settings = $config;
#phinx.php
<?php
require 'db_config.php';
return array(
    "paths" => array(
        "migrations"    => "db/migrations",
        "seeds"         => "db/seeds"
    ),
    "environments"   => array(
        "defaut_migration_table"    => "phinxlog",
        "default_database"          => "lleg",
        "default_environment"       => "development"
        "production"   => array(
            "adapter"   => "mysql",
            "host"      => $settings["DB_HOST"],
            "name"      => $settings["DB_NAME"],
            "user"      => $settings["DB_USER"],
            "pass"      => $settings["DB_PWD"],
            "port"      => 3306,
            "charset"   => "utf8"
        ),
        "development"   => array(
            "adapter"   => "mysql",
            "host"      => $settings["DB_HOST"],
            "name"      => $settings["DB_NAME"],
            "user"      => $settings["DB_USER"],
            "pass"      => $settings["DB_PWD"],
            "port"      => 3306,
            "charset"   => "utf8"
        )
    )
);

4.執行 php vendor/bin/phinx status 檢視連線狀態

5.執行 php vendor/bin/phinx create migration

6.現在生成了created /db/migrations/20180310020523_migration.php

編輯這個檔案,新增資料庫建立內容.

public function change() {
        $user = $this->table('user');
        $user->addColumn('open_id', 'string', ['limit'=>64]);
        $user->addColumn('register_time', 'timestamp', ['default' => 'CURRENT_TIMESTAMP']);
        $user->addColumn('favorite_music', 'integer', ['default'=> 0, 'comment'=>'喜歡的音樂']);
        $user->addColumn('favorite_vedio', 'integer', ['default'=> 0, 'comment'=>'喜歡的視訊數']);
        $user->addColumn('favorite_article', 'integer', ['default'=> 0, 'comment'=>'喜歡的文章數']);
        $user->addColumn('baby_birthday', 'date', ['null'=>true, 'comment'=>'寶寶生日']);
        $user->addColumn('baby_sex', 'boolean', ['null'=>true, 'comment'=>'寶寶性別']);
        $user->addColumn('last_login', 'datetime', ['null'=>true, 'comment'=>'最後登陸日期']);
        $user->save();
    }

7.預設會新增一個自增id,作為主鍵

執行 php vendor/bin/phinx migrate

8.初始化資料

執行 php vendor/bin/phinx seed:create CategorySeeder

系統自動建立 created ./db/seeds/CategorySeeder.php

9.修改 CategorySeeder.php

執行 php vendor/bin/phinx seed:run 將會進行所有Seed

10.如果想執行指定的Seed需要用- s引數指定

php vendor/bin/phinx seed:run -s CategorySeeder

11.更新表結構

當需要更新表結構的時候,需要再建立一個migrate

執行php vendor/bin/phinx create ChangeArtist

再將需要更新的內容寫到change函數

public function change() {
        $this->execute('alter table resource drop column artist ;');
        $resource = $this->table('resource');
        $resource->addColumn('artist', 'string', ['limit'=>128, 'default'=>'']);
        $resource->update();
    }

最後執行php vendor/bin/phinx migrate

之前的已經執行過的migrate不會執行, 只會執行更新的部分。

12.回滾

php vendor/bin/phinx rollback

13.資料填充

php vendor/bin/phinx seed:create UserSeeder
php vendor/bin/phinx seed:run -e product

生成檔案

<?php
use Phinx\Seed\AbstractSeed;
class UserSeeder extends AbstractSeed {
    /**
     * 插入資料
     */
    public function run() {
        $data = array(
          array(
              'id'    => 1,
          ),
          array(
              'id'    => 2,
          )
        );
        $posts = $this->table('users');
        $posts->insert($data)->save();
    }
}

phinx特別適合在開發,測試,線上資料庫同步欄位資訊,資料資訊,生成和同步測試資料等,所以特別適合在團隊開發流程中使用,尤其是對於一個新專案,只要在專案的開始就一直堅持使用phinx獨立部署,那麼每次變更資料庫表資訊團隊成員都可以通過git或者svn的方式同步程式碼然後執行上面提到的執行命令來同步庫表資訊,以此避免傳統開發時不同開發環境同步庫表資訊的繁瑣和失誤的情況。

在phinx.php 有一個設定項」default_migration_table」 => 「phinxlog」 這裡是記錄變更記錄的,這也是保障不會重複執行的一個措施,所以不用擔心丟失或者重複操作執行命令。

推薦學習:《》

以上就是教你使用PHP資料庫遷移工具「Phinx」的詳細內容,更多請關注TW511.COM其它相關文章!