站長資訊網
最全最豐富的資訊網站

教你使用PHP數據庫遷移工具“Phinx”

本篇文章給大家分享關于PHP處理中數據庫遷移工具Phinx的相關知識,phinx特別適合在開發、測試、線上數據庫同步字段信息、數據信息、生成和同步測試數據等,希望對大家有幫助。

教你使用PHP數據庫遷移工具“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 PhinxSeedAbstractSeed; 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視頻教程》

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
亚洲日韩乱码中文字幕| 日韩乱码在线观看| 91麻豆精品国产一级| 亚洲av无码成人精品国产| 国产精品久久久久网站| 日韩一区二区三区射精| 久久久99精品成人片中文字幕| 国产亚洲精品美女久久久| 久久99精品久久水蜜桃| 国产精品真实对白精彩久久| 国产精品视频免费一区二区三区| 日韩精品一区二区三区中文精品| 99在线视频精品| 国产精品视频一区国模私拍| 久久精品无码一区二区三区日韩 | 国产精品福利电影| 日产精品卡2卡三卡乱码网址| 亚洲精品tv久久久久| 久久精品国产亚洲AV麻豆王友容 | 亚洲日韩精品无码专区加勒比☆| 久久99精品国产99久久6| 亚洲国产综合91精品麻豆 | 亚洲午夜国产精品无卡| 四虎永久在线精品视频| 国内精品伊人久久久久影院对白| 久久成人国产精品免费软件 | 精品视频国产狼人视频| 成人精品视频99在线观看免费| 99久久99久久久99精品齐| 精品午夜国产人人福利| 四虎8848精品永久在线观看| 久久久久精品国产亚洲AV无码| 亚洲精品国偷自产在线| 国产精品99久久精品| 日韩乱码在线观看| 国产精品青草久久| 91成人午夜在线精品| 中文国产成人精品久久一区| 日韩一区二区三区视频| 久久夜色撩人精品国产av| 在线涩涩免费观看国产精品|