真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何使用PHP數(shù)據(jù)庫遷移工具Phinx

這篇文章給大家分享的是有關(guān)如何使用PHP數(shù)據(jù)庫遷移工具Phinx的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)建站主要為客戶提供服務(wù)項目涵蓋了網(wǎng)頁視覺設(shè)計、VI標(biāo)志設(shè)計、全網(wǎng)營銷推廣、網(wǎng)站程序開發(fā)、HTML5響應(yīng)式網(wǎng)站建設(shè)、成都做手機(jī)網(wǎng)站、微商城、網(wǎng)站托管及網(wǎng)站維護(hù)公司、WEB系統(tǒng)開發(fā)、域名注冊、國內(nèi)外服務(wù)器租用、視頻、平面設(shè)計、SEO優(yōu)化排名。設(shè)計、前端、后端三個建站步驟的完善服務(wù)體系。一人跟蹤測試的建站服務(wù)標(biāo)準(zhǔn)。已經(jīng)為成都公路鉆孔機(jī)行業(yè)客戶提供了網(wǎng)站維護(hù)服務(wù)。

如何使用PHP數(shù)據(jù)庫遷移工具Phinx

1.安裝

composer require nhzex/think-phinx

2.執(zhí)行

php vendor/bin/phinx

直接運(yùn)行 php vendor/bin/phinx init 可生成配置文件

另外一種方法是直接使用php文件做配置文件

直接運(yùn)行 php vendor/bin/phinx init 可生成配置文件

另外一種方法是直接使用php文件做配置文件

3.使用phinx.php進(jìn)行配置

 'localhost',
    'DB_NAME' => 'root',
    'DB_USER' => 'root',
    'DB_PWD' => '',
);
$settings = $config;
#phinx.php
 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.執(zhí)行 php vendor/bin/phinx status 查看連接狀態(tài)

5.執(zhí)行 php vendor/bin/phinx create migration

6.現(xiàn)在生成了created /db/migrations/20180310020523_migration.php

編輯這個文件,添加數(shù)據(jù)庫創(chuàng)建內(nèi)容.

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'=>'喜歡的視頻數(shù)']);
        $user->addColumn('favorite_article', 'integer', ['default'=> 0, 'comment'=>'喜歡的文章數(shù)']);
        $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.默認(rèn)會添加一個自增id,作為主鍵

執(zhí)行 php vendor/bin/phinx migrate

8.初始化數(shù)據(jù)

執(zhí)行 php vendor/bin/phinx seed:create CategorySeeder

系統(tǒng)自動創(chuàng)建 created ./db/seeds/CategorySeeder.php

9.修改 CategorySeeder.php

執(zhí)行 php vendor/bin/phinx seed:run 將會進(jìn)行所有Seed

10.如果想運(yùn)行指定的Seed需要用- s參數(shù)指定

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

11.更新表結(jié)構(gòu)

當(dāng)需要更新表結(jié)構(gòu)的時候,需要再創(chuàng)建一個migrate

執(zhí)行php vendor/bin/phinx create ChangeArtist

再將需要更新的內(nèi)容寫到change函數(shù)

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

最后執(zhí)行php vendor/bin/phinx migrate

之前的已經(jīng)執(zhí)行過的migrate不會執(zhí)行, 只會執(zhí)行更新的部分。

12.回滾

php vendor/bin/phinx rollback

13.數(shù)據(jù)填充

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

生成文件

 1,
          ),
          array(
              'id'    => 2,
          )
        );
        $posts = $this->table('users');
        $posts->insert($data)->save();
    }
}

phinx特別適合在開發(fā),測試,線上數(shù)據(jù)庫同步字段信息,數(shù)據(jù)信息,生成和同步測試數(shù)據(jù)等,所以特別適合在團(tuán)隊開發(fā)流程中使用,尤其是對于一個新項目,只要在項目的開始就一直堅持使用phinx獨(dú)立部署,那么每次變更數(shù)據(jù)庫表信息團(tuán)隊成員都可以通過git或者svn的方式同步代碼然后執(zhí)行上面提到的執(zhí)行命令來同步庫表信息,以此避免傳統(tǒng)開發(fā)時不同開發(fā)環(huán)境同步庫表信息的繁瑣和失誤的情況。

在phinx.php 有一個配置項”default_migration_table” => “phinxlog” 這里是記錄變更記錄的,這也是保障不會重復(fù)執(zhí)行的一個措施,所以不用擔(dān)心丟失或者重復(fù)操作執(zhí)行命令。

感謝各位的閱讀!關(guān)于“如何使用PHP數(shù)據(jù)庫遷移工具Phinx”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


當(dāng)前文章:如何使用PHP數(shù)據(jù)庫遷移工具Phinx
網(wǎng)站地址:http://weahome.cn/article/jhohsj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部