濮阳杆衣贸易有限公司

主頁 > 知識庫 > 多個Laravel項目如何共用migrations詳解

多個Laravel項目如何共用migrations詳解

熱門標簽:合肥企業(yè)外呼系統(tǒng)線路 代理打電話機器人 電信外呼系統(tǒng)多少錢一個月 萍鄉(xiāng)商鋪地圖標注 太原400電話申請流程 企業(yè)400電話辦理多少費用 神龍斗士電話機器人 宿州正規(guī)外呼系統(tǒng)軟件 桂陽公司如何做地圖標注

前言

在實際開發(fā)中,我們可能經(jīng)常會遇到一個項目會建立兩個 Laravel 項目,一個是面向用戶的 web/API,一個是管理員后臺,這兩個項目一般情況下是共用一個數(shù)據(jù)庫的,那么我們的 migration 可以共用嗎?該怎么操作?

Migration就相當于數(shù)據(jù)庫的版本控制工具,可以使用

php artisan migration

生成數(shù)據(jù)庫表,但前提是要在database目錄下有相應的表的PHP文件

下面話不多說了,來一起看看詳細的介紹吧

在各項目里建各自 migration

我們先在 web/API 和 admin 里都建各自的 migration:

## web 目錄

php artisan make:migration foo
# Created Migration: 2018_09_19_144940_foo

php artisan migrate
# Migration table created successfully.
# Migrating: 2018_09_19_144940_foo
# Migrated: 2018_09_19_144940_foo

php artisan migrate:status
# +------+-----------------------+-------+
# | Ran? | Migration    | Batch |
# +------+-----------------------+-------+
# | Yes | 2018_09_19_144940_foo | 1  |
# +------+-----------------------+-------+

## admin 目錄

php artisan make:migration bar
# Created Migration: 2018_09_19_145255_bar

php artisan migrate
# Migrating: 2018_09_19_145255_bar
# Migrated: 2018_09_19_145255_bar

php artisan migrate:status
# +------+-----------------------+-------+
# | Ran? | Migration    | Batch |
# +------+-----------------------+-------+
# | Yes | 2018_09_19_144940_foo | 1  |
# +------+-----------------------+-------+
# | Yes | 2018_09_19_145255_bar | 2  |
# +------+-----------------------+-------+

從 artisan migrate:status 的結果來看,兩個 migration 都正常執(zhí)行了,接下來我們試一下回滾操作。

先直接在 web 目錄執(zhí)行

php artisan migrate:rollback
# Migration not found: 2018_09_19_145255_bar

報錯了,因為在 web 項目里找不到 bar 這個 migration 文件;那如果我們剛剛是直接在 admin 目錄執(zhí)行,是能夠正常回滾的,但是如果我們指定回滾兩個版本:

php artisan migrate:rollback --step=2

# Migration not found: 2018_09_19_144940_foo
# Rolling back: 2018_09_19_145255_bar
# Rolled back: 2018_09_19_145255_bar

這次回滾操作也是有問題的,只回滾了一半。

所以我們應該按照 migrate 的相反順序執(zhí)行回滾,即先在 admin 執(zhí)行一次,然后再到 web 里再執(zhí)行一次。我們上面的實驗很簡單,要記住這些順序也不難,可是在實際的項目中,你的 migrations 就比這個復雜多了,而且只通過 migrate:status 你也看不出來執(zhí)行順序到底是怎么樣的,所以在各個項目里各自維護各自的 migrations 似乎行不通...

共用一份 migration

上面的實驗我們可以知道,我們在執(zhí)行 artisan migrate 的時候,Laravel 會讀取 migrations 目錄里的文件和數(shù)據(jù)庫里的記錄,然后再執(zhí)行相應的操作(并記錄這次操作);回滾的時候 Laravel 會讀取數(shù)據(jù)庫中的記錄,然后執(zhí)行 migrations 目錄里相應的文件中的 down 方法。

而當 migrations 分散在不同的項目(目錄)里的時候,不管你在哪個項目中執(zhí)行 migrate:rollback 時,都可能只有一部分 migration 文件被加載進來,因此會造成一些奇奇怪怪的問題。

那我們可以將所有 migrations 放在同一個地方,怎么操作呢?再建一個新的項目似乎有點麻煩了...我們先看看幫助吧:

php artisan migrate --help

Description:
 Run the database migrations

Usage:
 migrate [options]

Options:
  --database[=DATABASE] The database connection to use
  --force    Force the operation to run when in production
  --path[=PATH]   The path to the migrations files to be executed
  --realpath    Indicate any provided migration file paths are pre-resolved absolute paths
  --pretend    Dump the SQL queries that would be run
  --seed     Indicates if the seed task should be re-run
  --step     Force the migrations to be run so they can be rolled back individually
 -h, --help     Display this help message
 -q, --quiet    Do not output any message
 -V, --version    Display this application version
  --ansi     Force ANSI output
  --no-ansi    Disable ANSI output
 -n, --no-interaction  Do not ask any interactive question
  --env[=ENV]   The environment the command should run under
 -v|vv|vvv, --verbose  Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug

果然有我們想要的東西:--path 和 --realpath,先來看看這兩個參數(shù)是什么用途:

--path[=PATH]  指定 migrations 文件的路徑
--realpath     表示 --path 指定的路徑為絕對路徑

那我們在進行 migrations 操作的時候,指定同一個路徑,那就可以共用 migrations 了:

php artisan make:migration foo --path="../admin/database/migrations"

# or

php artisan make:migration foo --path="/the/absolute_path/to/admin/database/migrations" --realpath


# migrate
php artisan migrate --path="../admin/database/migrations"

# migrate:rollback
php artisan migrate:rollback --path="../admin/database/migrations"

注:當你不帶 --realpath 的時候,path 是以項目的根目錄為 / 的

總結

所以,當我們需要在多個 Laravel 項目中共用 migrations 的時候,最好的做法是通過 --path 指定 migrations 文件的目錄,這個目錄可以是一個獨立的 git repo,也可以是其中一個 Laravel 項目(我個人推薦放在其中一個項目中,采用獨立的 git 分支),這樣既可以共用 migrations,在團隊協(xié)作的時候也不會混亂和出現(xiàn)沖突

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Laravel 5.4因特殊字段太長導致migrations報錯的解決
  • Laravel 5框架學習之數(shù)據(jù)庫遷移(Migrations)
  • 解決Laravel 不能創(chuàng)建 migration 的問題

標簽:辛集 衡陽 白銀 太原 鄂州 廊坊 綏化 崇左

巨人網(wǎng)絡通訊聲明:本文標題《多個Laravel項目如何共用migrations詳解》,本文關鍵詞  多個,Laravel,項目,如何,共用,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《多個Laravel項目如何共用migrations詳解》相關的同類信息!
  • 本頁收集關于多個Laravel項目如何共用migrations詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    荆州市| 泰宁县| 江口县| 湄潭县| 札达县| 高碑店市| 紫阳县| 阜城县| 南川市| 阿合奇县| 中山市| 横山县| 兴业县| 文水县| 玛曲县| 大化| 苏州市| 龙州县| 克拉玛依市| 元谋县| 德令哈市| 富阳市| 贵德县| 白山市| 天津市| 乐亭县| 报价| 南宫市| 通州市| 广灵县| 元谋县| 长岛县| 福清市| 彝良县| 上饶市| 义乌市| 慈利县| 临邑县| 大丰市| 溧水县| 崇信县|